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PREFACE 



This manual describes the IBM 1130 Assembler 
language and defines the programming rules. It is 
intended as reference material for ^he writing of 
an assembler source program and the accomplish- 
ment of the steps required to produce the resulting 
object program. For those without programming 
experience or a knowledge of the principles involved, 
the IBM publication, Introduction to IBM Data 
Processing Systems (Form F22-6517), is suggested 
as preliminary reading. 

Within this publication, all references to the 
"Monitor System" apply to Version 1 and Version 
2. Where the reference only applies to Version 1, 
the abbreviation DM1 is used. _Where the reference^ 
only applies to Version 2 DM2^is usea. 

The term "loader" as it applies to the 1130 
programming systems bav3 the following 
meanings: 

Card/Paper Tape - Relocating Loader 

Disk Monitor 1 - Loader 

Disk Monitor 2 - Core Load Builder 



For those without experience involving different 
number systems, i.e. , binary and hexadecimal, 
the publication IBM Student Text: Number Systems 
(Form C20-1618) is recommended. 



The reader should also be familiar with the 
following: IBM 1130 Functional Characteristic s 
(Form A26-5881) and IBM 1130 Computing System, 
Input/Output Units (Form A26-5890). 

The assembler language is valid for the 1130 
Disk Monitor Programming Systems and the 1130 Card/ 
Paper Tape Programming System. The operating 
procedures for the Monitor Assembler are described 
in the publications IBM 1130 Disk Monitor System 
Reference Manual (Form C26-3750), and IBM 1130 
Disk Monitor System, Version 2, Programming and 
Operator's Guide (Form (C 26 -3 717). 

The operating procedures for the 1130 Card/ 
Paper Tape Assembler are described in the publication 
IBM 1130 Card/Paper Tape Programming System 
Operator's Guide (Form C26-3629). 

The library subroutines for the 1130 systems 
are described in the IBM 1130 Subroutines Library 
manual, (Form C26-5929). 

MACHINE REQUIREMENTS 

The minimum machine configuration for assembling 
programs is as follows: 

IBM 1131 Central Processing Unit, Model 1, 

with 4096 words of core storage 
IBM 1442 Card Read Punch, or IBM 1134 Paper 

Tape Reader and IBM 1055 Paper Tape Punch. 
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Fifth Edition 

This edition is a revision of the previous edition (C26-5927-3) which is now obsol ete. 
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GENERAL DE SCRIPTION 



INTRODUCTION 

The IBM 1130 Assembler language replaces binary 
instruction codes with mnemonic symbols and uses 
labels for other fields of an instruction. Other fea- 
tures, such as pseudo-operations, expand the pro- 
gramming facilities of machine language. Thus, 
the programmer has available, through an assem- 
bler language, all the flexibility and versatility of 
machine language, plus facilities that greatly reduce 
machine language programming effort. 



Symbolic Language 

Symbolic language is the notation used by the pro- 
grammer to write (code) the program. A program 
written in symbolic language is called a source pro- 
gram. It consists of systematically arranged 
mnemonic operation codes, special characters, 
addresses, and data, which symbolically describe the 
problem to be solved by the computer. 
The use of symbolic language: 

• Makes a program independent of absolute core 
locations , thus allowing programs and subroutines 
to be relocated and combined as desired. 

• Allows subroutines that can be written indepen- 
dently and that cause no loss of efficiency in the 
final program. 

• Permits instructions to be added to or deleted 
from a source program without the user having 
to reassign storage addresses. 



Assembler Program 

The assembler program converts (assembles) a 
source program into a machine -language program. 
The conversion usually is one for one — that is, the 
assembler produces one machine-language instruc- 
tion for each symbolic-language instruction. 

The 1130 Disk Monitor Assembler is a two-pass 
assembler. The source program is read into core 
from the principal input device and written on the disk 
for use in pass 2. During the first pass the symbol 
table is generated. During the second pass the object 



program is created in the system Working Storage 
and the listing, if requested, is produced. 

The IBM 1130 Card/Paper Tape Assembler is a 
two-pass program. It is loaded into the computer 
and is followed by the first pass of the source program. 
During the first pass, the source statements are 
read and a symbol table is generated. During the 
second pass, the source program is read again and 
the object program and/or error indications are 
punched into the first 20 columns of each source card. 
If paper tape is used, the second pass results in the 
punching of a new tape that contains both source state- 
ments and corresponding object information. Both 
card and tape object programs must be compressed 
(via a Compressor Program supplied with the assem- 
bler) into a relocatable binary deck (or tape) before 
they can be loaded into core storage for execution. 
The output from the second pass is called the list 
deck (or tape) and can be used to obtain a program 
listing of source statements and corresponding object 
statements. 



Subroutines 

A library of input/output, arithmetic, and functional 
subroutines is available for use with the IBM 1130 
Assembler. 

The user can incorporate any subroutine into his 
program by simply writing a call statement (CALL or 
LIBF, whichever is required), referring to the sub- 
routine name. The assembler generates the linkage 
necessary to provide a path to the subroutine and a 
return path to the user's program. The ability to use 
subroutines simplifies programming and reduces the 
time required to write a program. 

A description of available subroutines is con- 
tained in the system subroutine library manual. 



FEATURES OF THE ASSEMBLER 

The significant features of the IBM 1130 Assembler 
are summarized below. More detailed explanations 
are given later in this manual. 

Mnemonic Operation Codes. Mnemonic operation 
codes are used for all machine instructions instead 
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of the more cumbersome internal binary operation 
codes of the machine. For example, the Subtract 
instruction can be represented by the mnemonic, S, 
instead of the machine operation code, 10010. 

Symbolic References to Storage Addresses. Instruc- 
tions, data areas, and other program elements can 
be referred to by symbolic names or actual machine 
addresses and designations. 

Renaming Symbols. A symbolic name can be equated 
to another symbol, so that both refer to the same 
storage location. This makes it possible for the 
same program item to be referred to by different 
names in different parts of the program. 

Automatic Storage Assignment. The assembler 
assigns consecutive addresses to program elements 
as it encounters them. After processing each ele- 
ment, the assembler increments a counter by the 
number of words assigned to that element. This 
counter indicates the storage location available to 
the next element. 



Relocatable Programs. The assembler can produce 
object programs in a relocatable format; that is, a 
format that enables programs to be loaded and exe- 
cuted at storage locations different from those 
assigned when the programs were assembled. 

Convenient Data Representation. Constants can be 
specified as decimal digits, alphabetic characters, 
hexadecimal digits, and storage addresses. Conver- 
sion of the data into the appropriate machine format 
of the 1130 System is performed by the Assembler. 
Data can be in a form suitable for use in decimal 
integer, fixed-point, or real arithmetic operations. 

Program Listings. For every assembly, the user 
can obtain a program listing. This listing can be 
produced either off-line (Card/Paper Tape Assem- 
bler) or on-line during the assembly process (Disk 
Monitor Assembler). 

Error Checking . Source programs are examined by 
the Assembler for errors arising from incorrect use 
of the language. Where an error is detected, a coded 
warning message appears in the program listing. 



■ 



MNEMONIC CONCEPT 

Symbolic programming may be defined as a method 
whereby names and symbols are used to write a pro- 
gram. The symbolic language includes a standard 
set of mnemonic operation codes. Mnemonic opera- 
tion codes are easier to remember than machine lan- 
guage codes because they are usually abbreviations 
for actual instruction descriptions. For example: 



Description 

Add 
Execute I/O 



Mnemonic 

A 
XIO 



Each IBM 1130 machine instruction has a cor- 
responding mnemonic operation code. In addition, 
there are some mnemonic codes that assign storage 
and others that allow the user to exercise control 
over the assembly process. 



FORMAT OF STATEMENTS 



SYMBOLIC LANGUAGE 



Label Field (Columns 21-25) 

The label field represents the machine location of 
either data or instructions. The field may be left 
blank, may contain an asterisk in column 21, or 
may be filled with a symbolic address, left-justified 
in the field. Only data or instructions that are re- 
ferred to elsewhere in the program need a label, 
although a label that is not further referred to is 
not an error. 

A label can consist of up to five alphameric 
characters, beginning at the leftmost position of the 
label field. A label is always a symbol and must 
therefore conform to the rules for symbols (see 
Symbols) . The example below shows the symbol 
ALPHA used as a label. 



AX.P.H.Amsr.a 



Ope ratio 



An, ,E,x,p,r,e,s,s,/', 



o,i% 



_) I L_l 1_ 



A source program consists of a sequence of state- 
ments. These statements can be written on a stan- 
dard coding form (X26-5994) provided by IBM. The 
information on each line of the form (Figure 1) is 
punched into one card or paper tape record or en- 
tered from the keyboard. The first position on the 
form (21) corresponds to card column 21 or to the 
first character of the paper tape/keyboard record. 
Space is provided at the top of the coding form to 
identify the program; however, none of this informa- 
tion is punched into the statement cards. The first 
20 columns of an assembler source card must be 
blank. 

NOTE: Keyboard input is acceptable only with the 
Monitor 2 Programming System. 



Statement Fields 

An assembler statement is composed of one to seven 
fields: label field, operation field, format field, tag 
field, operand field, comments field, and identifica- 
tion sequence field. 



If the label field is left blank, it is ignored by 
the Assembler and has no effect on the assembled 
program. If column 21 contains an asterisk (*), the 
entire statement is treated as comments and appears 
only in the listing. If the field contains a symbolic 
name (label), and the statement represents a standard 
machine language operation (Add, Store, etc.), the 
value assigned to the label is the address of the 
assembled instruction, which is equal to the value of 
the Location Assignment Counter (see Location As- 
signment Counter) at the time the statement is en- 
countered by the Assembler. Values assigned to 
labels of the various assembler instructions are 
specified in the section entitled Assem bler 
Instructions. 

Operation Field (Columns 27-30) 

Each machine instruction and assembler instruction 
has a unique mnemonic operation code associated 
with it. When a particular operation is to be repre- 
sented, its mnemonic code must be punched, left- 
justified, in columns 27-30 of the source statement 
record. 
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Figure 1. Coding Form 



Format Field (Column 32) 

The format field specifies the type of machine in- 
struction being represented and, in the use of short 
(one-word) instructions, how the displacement field 
is to be handled. Any one of four entries is per- 
mitted: two for short instructions, one for a direct 
long (two-word) instruction, and one for an in- 
directly-addressed long instruction. For conven- 
ience, these formats are referred to by the charact- 
er used to specify them, namely blank format, X 
format, L format, and I format. 



Blank Format. A blank in the format field (column 
32) signifies a short instruction except with some 
of the extended mnemonics provided with the Disk 
Monitor Assembler, in which case a blank format 



field specifies a long instruction. Bit 5 of the 
assembled instruction is set to zero. A blank also 
indicates that any expression in the operand field be 
interpreted as the desired effective address for the 
statement. 

During execution of certain short instructions, 
the effective address is the sum of the displacement 
(last 8 bits of the instruction word) and the contents 
of the Instruction Address Register (IAR). A blank 
format for such instructions causes the assembler to 
subtract the current value of the Location Assignment 
Counter from the expression in the operand field. 
Thus, when this result is added to the IAR during 
execution of the instruction, the correct effective 
address is obtained. 

The effective address of short Store Index (STX) 
instructions is always obtained by adding the dis- 
placement to the IAR. The displacement of the Load 



Index (LDX), Load Status (LDS), WAIT, all shift 
instructions, and all condition testing instructions 
is never added to the IAR. The effective address of 
all other short instructions is obtained by adding 
the displacement to the IAR, if the instructions are 
not indexed; that is, if column 33 is blank or zero. 

The X format suppresses the automatic subtraction 
of the address counter from the displacement operand 
value when the instruction is moved. Therefore, the 
X format should be used for a short instruction which 
will have an effective address obtained by adding the 
displacement to the IAR. This requirement is not in 
conflict with the relocation process, because the 
process shifts the whole program, including instruc- 
tions and reference data, to a core storage area 
different from that for which it was assembled. The 
relative distances between instructions and data re- 
main the same, and the displacements remain correct. 

In a relocatable assembly, the expression speci- 
fying an operand modified by the IAR must be re- 
locatable so that the actual displacement is an ab- 
solute quantity (see Expressions) . If this rule is not 
followed, a relocation error will be indicated. Also, 
since displacements must lie in the range -128 
to +127 , the value of the displacement-specifying 
expression must not be more than 127 greater, 
nor more than 128 less than the address of the 
next location after the instruction in which it appears; 
otherwise, an addressing error will be indicated. 
An example illustrating the blank format is shown 
below : 



Assume A = location 1000 
B = location 1050 



10 
10 



The value of the IAR will be 1001 when 
instruction A is executed. Therefore, the value 
computed by the assembler for the displacement 
will be 49 . 



In the case of an instruction whose address is 
not modified by the IAR, the Assembler interprets 
the expression in the operand field as the desired 
contents of the displacement field, without modifica- 
tion. In this case, the operand specifying the dis- 
placement must be absolute and must be in the range 
-128 to +127 , or relocation and addressing errors 
result. 

X Format. An X in the format field indicates to the 
Assembler that the related statement is to be assem- 
bled as a short instruction. It further indicates that 
any expression in the operand field is to be inter- 
preted as the desired displacement value. 

Consider the example illustrated in Figure 2; 
the purpose of this instruction sequence is to change 
the flow of a program by inserting a branch instruc- 
tion in a location that previously contained a "no 
operation. " If the branch instruction at BR CON 
were specified as MDX GO (i. e. , blank format), 
the assembler would compute the displacement 
on the basis of the IAR value of 1101. (The IAR 
would have a value of 1101 if the BRCON instruction 
were executed where it was assembled.) However, 
the programmer, knowing the instruction will be 
executed at location SWTCH, computes the dis- 
placement himself and specifies the X format. 

L Format. If column 32 contains the character L, it 



signifies a long (two -word) instruction with direct 
addressing. Bit 5 (F) of the assembled instruction 
is set to 1. The operand-field expression, which may 
be relocatable or absolute, is used to fill the second 
word (bits 16-31) of the assembled instruction. A 
second operand may be present, separated from the 
first operand by a comma (,). This operand may be 
used in one of two ways: 

1. To specify symbolic condition codes for use with 
BSC, BSI and BOSC instructions. 

2. To specify an expression that has a value in the 
range of -128 to +127 and is not relocatable. 
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This second operand yields bits to fill bit positions 
8-15 of the assembled instruction. 

I-Format. If column 32 contains the character I, it 
signifies an indirectly addressed long instruction. 
Bit 5 and bit 8 are set to 1. In all other respects 
an indirect instruction is treated exactly as a long 
direct instruction. If a displacement operand is 
specified, its high-order bit (bit 8) will always be 
a one, causing the displacement to be negative, 
because this bit is also the indirect flag bit. 
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Figure 2. Use of X Format 



Tag Field (Column 33) 

Column 33 is used to specify an index register if 
one is required. The code in column 33 is the index 
register number; i.e. , l=Index Register 1, 2=Index 
Register 2, and 3=Index Register 3. A zero or a 
blank indicates that no index register is to be used. 

If no tag is specified in an LDX, MDX, or STX 
instruction, the IAR is used. The example below 
shows an add instruction that addresses the core 
location whose address is zero plus the contents 
of Index Register 2. 



S,UM , 



Ope rati 




sis 



Operandi & Fe 



Operands and Remarks Field (Columns 35-71) 

The operand field is used to specify subfields in in- 
structions and constants. The content of the operand 



field for the various instruction formats are de- 
scribed under Format Field. Blanks must not appear 
within the operand(s) except as character values or 
in the EBC statements. 

Some examples of one- and two-operand state- 
ments are shown in Figure 3. 

Remarks Field 

Remarks are for the convenience of the programmer. 
They permit lines or paragraphs of descriptive infor- 
mation about the program to be inserted in the pro- 
gram listing. Remarks appear only in the program 
listing; they have no effect on the assembled object 
program. Any valid characters (including blanks) 
can be used as remarks. 

The Remarks field must appear to the right of 
the operand field and must be separated from it by 
at least one blank. 

Comments Field 

By placing an asterisk in column 21, the combined 
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Figure 3. One- and Two-Operand Statements 



statement fields from columns 22-72 may be used 
for comments. The identification-sequence field 
(columns 73-80) should not be used for comments. 
If it is necessary to continue comments on ad- 
ditional lines, each line must have an asterisk in 
column 21, as illustrated in Figure 4. 

Identification-Sequence Field (Columns 73-80) 

The identification-sequence field may be used for 
program identification and statement-sequence num- 
bers. It is limited to columns 73-80. The informa- 
tion in this field normally is punched in every state- 
ment card. The Assembler, however, does not 
check this field. 



STATEMENT WRITING 

Symbolic language statements are accepted by the 
Assembler only if they conform to the rules of syntax 
presented in this section. Subsequent sections of this 
publication deal with the format and content of the 
specific types of assembler statements (machine in- 
structions and assembler instructions). Instructions 
of both types are formed by using the basic elements 
described here. Many of the points introduced in this 
section are covered more extensively in subsequent 
sections. 



Character Set 



The following characters may be used in statements: 



Monocase Alphabetics 

Numerics 

Special Characters 



A through Z, $, #, @ 
through 9 
/*+-=& | ~~» <> 

'.,:;()%-? 
(blank) 



The codes that the assembler accepts for these 
characters are listed in Appendix A. Appendix A 
also lists additional codes which may be used in com- 
ments statements, as character values, and as 
alphameric constants. The + and & special char- 
acters may be used interchangeably as operators. 



Symbols 

Storage areas, instructions, and other elements may 
be given symbolic names for the purpose of referring 
to them in the program. The symbolic name is called 
a symbol. It can contain up to five characters. 



While the first character of a symbol must be alpha- 
betic, the remainder may be alphabetic, numeric, or 
any combination of the two. No embedded blanks or 
special characters may be used. Any violation of 
these rules is detected by the Assembler and indi- 
cated as an error in the program listing. 
The following are valid symbols: 



PUNCH 

A2345 



START 
LOOP 2 



N 
BC$#@ 



$, # and @ are monocase alphabetics, not special 
characters (see Character Set) , and as such can be 
used in the label field. 

The following symbols are invalid, for the 
reasons noted: 



256B 

RECORDAREA2 
END 1 



First character is not 

alphabetic 

More than 5 characters 

Contains a blank 



If a symbol is to be used as an operand, it must 
be defined in the program by using it as the label of 
a statement. Two types of label assignments are 
allowed. In machine-instruction statements and cer- 
tain assembler statements, the label is assigned an 
address equal to the current value of the Location 
Assignment Counter. In the Equate Symbol statement 
(see Symbol Definition Statement ), the label is 
assigned the value specified in the operand of the 
statement. 

Symbol Table. For every program assembled, a 
table of the symbols in that program is created. 
This is the symbol table; each entry in the table re- 
cords the value and relocation property of a symbol. 

All symbols defined in the program are entered 
in the symbol table. Symbols that appear in the 
label field of assembler instructions that do not use 
labels (for example, ABS, END, ENT) are not placed 
in the symbol table. 

General Restrictions on the Use of Symbols. The 
following restrictions are imposed on the use of 
symbols: 

• A symbol may appear only once in a program 
as the label of a statement. If a symbol is used 
as a label more than once, only the first usage 
is recognized. Each subsequent usage of the 
symbol as a label is ignored and, in the card/ 
paper tape system, is noted as an error in the 
program listing. In addition, any reference to 
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Operation 



»,t,h,£ , m s.T.e.x 



||: 32 



m 



Operandi & Remarks 



t\#. ,C,0,L, ,?■/, ^A.K.tS, .T.H./.S, .4. ,C,0./tQ*.f./tf,r.S. ./../. A/.C. 



«M , /Vj Ag ^ . f , * , / 






S> .l.f.g.tt /,*,£•,£, .f.a,*. .f.w.g,//. x./,M£, >o.f. ,c,o,M t At,e,A/,r,$ l 



-I 1 1 I I I I 1 I I I L_J I I I ■ I ■ 



I I I I » 



Figure 4. Example of Comments Statement 

such a symbol is noted as an error. 

• The number of symbols that can be defined in a 
program is restricted by the amount of core 
storage available to the assembler. The number 
of symbols allowed is defined in the system 
operator s manual. 



For example, in the sequence 



5.7 



H 



Lk 



\A^ 



i 



Operation 



s. T .a. 



£l_l_ 



P 



B.e.T.A 



\S i r J q ± fi 1 e 1 



|4±£i£i£il 



LJ,SJ t 



\L&£J^. 



I 



LOCATION ASSIGNMENT COUNTER 

The Assembler maintains a counter to assign sequen- 
tial storage addresses to program statements. This 
counter is called the Location Assignment Counter. 
It always indicates the next available address. As 
each machine instruction is processed, the counter 
is incremented by the number of words assigned to 
that instruction. Certain assembler instructions 
also cause the Location Assignment Counter to be 
set or incremented, whereas others do not affect it 
(see Assembler Instructions) . 

Location Assignment Counter Overflow. The maxi- 
mum value of the Location Assignment Counter is 
65535, a 16-bit value. If a program being assem- 
bled causes the counter to be incremented beyond 
65535, the Assembler retains only the rightmost 
16 bits in the counter and continues the assembly, 
checking for any other source program errors. No 
usable object program is produced. The user can, 
however, still obtain a listing of the entire source 
program. 



RELATIVE ADDRESSING 

Once an instruction has been named by a symbol in 
the label field, it is possible for other instructions 
to refer to that instruction by using the same symbol. 
Moreover, it is possible to refer to instructions pre- 
ceding or following the instruction named by indica- 
ting their positions relative to that instruction. This 
procedure is referred to as relative addressing. A 
relative address is, effectively, a type of expression 
(see Expressions) . 



control can be transferred to the second instruction 
by either of the following instructions: 



Label 

21 ?5 




Operation 

27 30 




F 

12 


T 

33 


M* 


35 40 


a 






B.S.C, 




L 




8j*j 


SiTAiRiTi+i f>t 
















i i i i i i i i i i « i i i 






6.S.C, 


8$ 


L 






"it. ,/ |S| / |""|3| 1 ;i 1 1 1 1 1 


1 1 1 1 




i i i 










1 1 1 1 1 ■ 1 1 1. 1 1 1 1... J. - 



By using relative addressing, it is also possible 
to refer to a particular word within a block of re- 
served storage. For example, the instruction 



ff. f .- M , 



Operation 



im 

1 F 



BSS. 



m 



m 



%5j&±_ 



_l I I I I I I I L. 



reserves a block of 50 words, in which BETA is the 
address assigned to the first word in the block. The 
address BETA+1 then refers to the second word, 
BETA +2 to the third word, and BETA+n to the (nth+1) 
word. 

Relative addressing can also be effected by using 
the current value of the Location Assignment Counter 
in an operand. In symbolic language this value is 
denoted by an asterisk (*). (See The Asterisk Used 
as an Element .) 



SELF-DEFINING VALUES 

A self-defining value is a machine value or a bit 
configuration. 



Self -defining values can be used to specify such 
program elements as data, masks, addresses, and 
address increments. The type of representation 
selected (decimal, hexadecimal, or character) de- 
pends on what is being specified. 



Decimal Values 

A machine decimal value is an absolute number from 
to 65535. It is assembled as its binary equivalent. 
Some examples of decimal, self-defining values are 

500 003 

17 52324 

7230 1 

K a number larger than 65535 is specified in address 
arithmetic, the value is truncated modulo 65536; 
that is, only the low order 16 bits of the binary value 
are retained. 

Hexadecimal Values 

A hexadecimal value is an unsigned hexadecimal 
number written as a sequence of digits. The digits 
must be preceded by a slash (/). The hexadecimal 
digits represent the 16 possible combinations of 
four bits . 

Each hexadecimal digit is assembled as its four 
bit value. The hexadecimal digits and their bit 
patterns are as follows: 

- 0000 4 - 0100 8 - 1000 C - 1100 

1 - 0001 5 - 0101 9 - 1001 D - 1101 

2 - 0010 6 - 0110 A - 1010 E - 1110 

3 - 0011 7 - 0111 B - 1011 F - 1111 

The following are examples of hexadecimal, 
self -defining values: 

/FFFF 

/AB12 

/379B 



/F2 
/00F2 



r equivalent 



If more than four hexadecimal digits are speci- 
fied in one sequence, only the four low -order digits 
are retained by the assembler. If less than four 
hexadecimal digits are specified, they are entered, 
right-justified. 

A table for converting decimal values to hexa- 
decimal values is provided in Appendix B. 

Character Values 

A character value is a single character, preceded 
by a period. A character value may be a blank, any 



combination of punches in a single card column, or 
a paper tape character that translates into the eight- 
bit IBM Extended BCD Interchange Code. Appen- 
dix A is a table of these combinations, their inter- 
change codes and, where applicable, their printer 
graphics. A period used as a character value is 
represented as two periods in sequence, (i. e. , . . ). 
Examples of character values are: 

.A 

. 1 

. 2 

. D 

. (blank) 
The same value can frequently be represented 
by any one of the three types of self -defining values. 
For example, the decimal value 196 can be expressed 
in hexadecimal as /C4 and as a character, . D. The 
selection of a particular type of value is left to the 
programmer. Decimal values can be used for actual 
addresses and input/output unit numbers, hexadeci- 
mal values for masks, and character values for 
data. 



EXPRESSIONS 

The term "expression" refers to symbols or self- 
defining values used as operands, either singly or 
in arithmetic combinations. Expressions are used 
to specify the various fields of machine instructions. 
They are also used as the operands of assembler- 
instruction statements. 

An expression has three components: elements, 
terms, and operators. 

Elements 



The smallest component of an expression is an 
element. An element is either a single symbol or 
a single self -defining value. The following are 
valid elements: 

TMP 
/1A6 
.B 

A 

* 

4 
The Asterisk Used As an Element 

When used as an element the asterisk is relocatable 
and stands for the current value of the Location 
Assignment Counter for the instruction in which it 
appears (i. e. , the rightmost word of the current 
instruction + 1). Thus, the asterisk as an element 
can have different values for different instructions. 
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Label 
21 25 




Operation 
27 30 




F 

32 


T 

3) 




33 40 45 






L.D. . 










n,8,C, iii 


WM . 




A. . , 










t £,F, . .......... 






5. , , 










O.AJ.A 


■ i i i 




e.s.c, 




L 






SiUM } .+. 


i iii 




1 1 1 










i i i i i i i i i i i i i i 



The last instruction is a conditional branch to 
location SUM and can be written 



Label 

21 23 




Operation 

27 JO 




F 

32 


T 

33 




35 40 45 






B.SC, 




L 








.1 * 1 i 




i i i 










1 ■ 1 1 . i 1 1 I . 1 1 1 | 



Be sure the asterisk refers to the proper word when 
it is used with a long instruction or in an area where 
long instructions are present. In the previous exam- 
ple, the B6C instruction will become two machine 
language words after assembly. Therefore, during 
assembly of the BSC instruction, the Location As- 
signment Counter contains a value one greater than 
if the BSC were a short instruction. 



position of the asterisk always makes clear what is 
meant. Thus, **10 means "the value of the Location 
Assignment Counter multiplied by 10. " 

Evaluation of Expressions 

From a symbolically written operand, the evaluation 
procedure derives an integer value that can be used 
as (1) a displacement value in a short instruction, 
(2) an address in a long instruction, or (3) an absolute 
numeric quantity. 

An expression is evaluated as follows: 



1. 
2. 



3. 



Each element is replaced by its numeric value. 
Each term is evaluated by performing the indi- 
cated multiplications from left to right, in the 
order in which they occur. In multiplication, 
the low-order 16 bits are retained. 
The terms are combined from left to right, in 
the order in which they occur. If the result is 
negative, it is replaced by its 2's complement. 



Grouping of terms, by parentheses or otherwise, 
is not permitted; however, this restriction can often 
be circumvented. For example, the product of 25 
times the quantity B-C can be expressed as 



Terms 



25 * B - 25 * C 



A term can consist of a single element, two elements 
separated by an asterisk (which denotes multiplica- 
tion) , or three elements each separated by an asterisk, 
etc. A term must begin with an element and end 
with an element, but is not permissible to write two 
elements in succession. The following are valid 
terms; 

TMP * FUNC * TAXY 

A * 4 

X * Y* 5 

6 * 4096 

3 

Operators 

An operator is a character that denotes an arithmetic 
function. The recognized operators are + or & (plus 
or ampersand), - (minus), and * (asterisk), denoting- 
addition, subtraction, and multiplication, respec- 
tively; An operator must be used between two terms. 
Two operators may not be used in succession. 

There is no ambiguity between the use of the 
asterisk as an element and the use of the asterisk 
as an operator to denote multiplication, because the 



Types of Expressions 

In addition to evaluating expressions, the Assembler 
must decide whether the expression is absolute 
or relocatable. Without this information the Assem- 
bler would be unable to assign the proper relocation 
indicator bits for use during loading. 

Rules for Determining the Type of Expression 

The rules by which the expression type is determined 
are: 

• A symbol that is defined by means of the Location 
Assignment Counter is a relocatable element. 

• Decimal and hexadecimal integers and character 
values are absolute elements. 

• A relocatable element alone is a relocatable 
expression. 

• A relocatable element, plus or minus an absolute 
element, is a relocatable expression. 
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• The difference of two relocatable elements is 
an absolute expression. 

• A symbol that has been equated to an expression 
(by means of the EQU assembler instruction) 
assumes the same relocation property as that 
expression. 

These rules are clarified by the following example: 

Assume that a programmer wishes to incorpor- 
ate a table into a relocatable program, and he knows 
that he may later wish to add or delete items with- 
out changing program references to the table. The 
first step is to assign symbols to the first (lowest- 
addressed) word in the table and to the location 
immediately after the last (highest-addressed) word 
of the table. These symbols could be BGTBL and 
ENTBL, respectively. Regardless of the number 
of items in the table or of the number of later 
additions or deletions, the number of words in the 
table is always equivalent to the value of the ex- 
pression ENTBL-BGTBL. This illustrates the rule 
that the difference of two relocatable elements is an 
absolute expression. 

Expanding this example, assume the programmer 
wishes to use a second table the same length as the 
first. The first (lowest addressed) word of the 
second table can be indicated by the symbol STBL. 
Then, the location following the last (highest-ad- 
dressed) word of the second table can be indicated 
by the expression 

STBL + ENTBL - BGTBL 

This address is subject to relocation; hence, the 
expression is relocatable, following the rule that &_ 
relocatable element plus or minus an absolute 
element is a relocatable expression. 

Procedure for Determining the Type of Expression 

The following paragraphs describe the procedure 
for determining expression type (absolute or 
relocatable) : 

• Discard any term that contains only absolute 
elements. 

• Examine each term of the expression. If any 
term contains more than one relocatable ele- 
ment, the expression will yield a relocation 
error. 



• Replace each relocatable element by the symbol 
r, and replace each absolute element by its 
value. This yields a new expression which in- 
volves only numbers and the symbol r. 

• Rewrite the expression in simplest form by 
evaluating it according to the address arithmetic 
rules given above in the section, Evaluation of 
Expressions. 

If .the result is an integer, the operand is absolute. 
If the result is r, the expression is relocatable. If 
the result contains r to any power other than one, or 
contains r with a coefficient other than one, the 
operand does not have a well-defined relocation 
property and will yield a relocation error. The 
following examples illustrate this procedure. 

NOTE: When the terms absolute symbol and reloca- 
table symbol are used in text, they mean symbols 
that refer to addresses. 

Example 1: Consider the expression, 

4-0*TRANS}f*FUNCjKX>UNT 

where TRANS and FUNC are relocatable symbols, 
and COUNT is an absolute symbol. Discarding the 
terms involving only absolute elements leaves 

3*TRANS-2*FUNC 

This does not contain any illegal terms. Replacing 
each symbol by the letter r results in 

3*r-2*r 

Evaluating this produces r; therefore, the expression 
is relocatable. 

Example 2: Consider the expression, 

2*3*TRANS-FUNC 

This reduces to 

i2*3*rj-r 



or 



5r 
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This is neither r nor a number; therefore, the 
expression will cause a relocation error. 

Example 3: Consider the expression, 

A*2*R-A*A*R+5 

where A is an absolute symbol, and R is a relocata- 
ble symbol. The expression is absolute if the value 
of A is zero or two and relocatable if the value of A 
is 1. If the value of A is anything else, a relocation 
error will result. 

In the following examples, A, B, C, and D are 
relocatable symbols, and J, K, L, M, and N are 
absolute symbols. 

Relocatable expressions: 



A 




1*A 


A+J 




250*A-249*B 


A+B+i 


C-D-* 


100*A+50*B-75*C-74*D 



Absolute expressions: 



Relocation Errors 

If a source program contains an expression having in 
it one or more of the following, that expression is 
flagged as a relocation error. 

• The negative (complement) of a relocatable 
element 

• An absolute element minus a relocatable element 

• The sum of two relocatable elements 

In the following examples, A, B, C, and D are 
relocatable symbols, and J, K, L, M, and N are 
absolute symbols. 



I 



A+B 

-A 

15-* 



<+2r) 
<-lr) 
<-lr) 



A*B 
2*A 
5*A-6*A 



<r 2 ) 
(2r) 



(-lr) 



A+ J+M+N+B -C+D+ L(+2r ) 



12345 
A-B+C-D+5 



0*A 
500*A-400*B-100*C 



NOTE: In an absolute assembly headed by an ABS 
statement (described later), all symbols and asterisk 
values are defined as being absolute; therefore, no 
relocation errors are possible. 
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MACHINE-INSTRUCTION STATEMENTS 



All machine instructions can be represented symbol- 
ically as assembler language statements. There are 
two basic formats: short and long. However, with- 
in each basic format, further variations are possible. 

The symbolic format of a machine instruction 
parallels, but does not duplicate, its actual format. 
A mnemonic operation code is written in the opera- 
tion field, and one or more operands are written in 
the operand field. Comments can be appended to a 
machine -instruction statement as previously ex- 
plained. 

Any machine-instruction statement can be named 
by a symbol, which other assembler statements can 
use as an operand. The value of the symbol is the 
address of the leftmost word assigned to the assem- 
bled instruction. 



Unique 
Character Condition 

O (Alpha) Overflow 



Carry 



Even 



+ or & Plus 



Minus 



Description 

Skip or do not branch 
if Overflow indicator off 

Skip or do not branch 
if Carry indicator off 

Skip or do not branch 
if bit 15 of Ace =0 

Skip or do not branch 
if bit of the Ace =0 , 
but not all bits of Ace 
=0 

Skip or do not branch 
if bit of Ace =1 



Bit Position 
Set to 1 

15 



14 



13 



12 



11 



MNEMONICS 



Zero 



Skip or do not branch 
if all bits of Ace =0 
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A list of all IBM 1130 machine language instructions 
and their associated mnemonics, including those 
mnemonics available for the monitor system only, is 
given in Table 1. 

Condition-Testing Instructions (BSC, BO SC, BSI) 

The machine instructions Branch or Skip on Condition 
(BSC), Branch Out or Skip on Condition (BOSC), 
and the long form of Branch and Store Instruction 
counter (BSI) use bits 10-15 of the displacement to 
test any combination of six conditions associated with 
the accumulator. When coding these instructions , the 
user does not use an expression to specify the dis- 
placement field, but, instead, writes a series of 
unique characters, each of which represents one bit 
of the condition -testing mask. These character 
symbols may be written in any combination; the bits 
they represent are combined by the assembler in a 
logical OR fashion. The symbols and their repre- 
sentations are: 



Examples: 




Skip on plus condition 

Skip on non-zero (plus or minus) 

Skip on non-plus (zero or minus) 

Skip if Carry indicator off 

Branch to EXIT if not plus 
(zero or minus) 

Branch to EXIT if zero 
(not plus or minus) 

Unconditional Branch to EXIT 

Branch to the contents of XR1 if minus 
(not zero or plus) 

Branch and Store instruction counter 
to SUBR if Overflow is on 
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Table 1. Machine Instruction Mnemonics 



Mnemonic 




OP Code , 


; Instruction 




Load and Store 


(Hexadecimal Representation) 








LD 




COO 


Load Accumulator 




LDD 




C80 


Load Double 




LDX 




600 


Load Index 




LDS* 




200 


Load Status 




STO 




D00 


Store Accumulator 




STD 




D80 


Store Double 




STX 




680 


Store Index 




STS 




280 


Store Status 




Arithmetic 










A 




800 


Add 




AD 




880 


Add Double 




S 




900 


Subtract 




SD 




980 


Subtract Double 




M 




A00 


Multiply 




D 




A80 


Divide 




AND 




E00 


And 




OR 




E80 


Or 




EOR 




F00 


Exclusive Or 




MDM 


+ 5 


740 


Modify Memory 




Branch 










B 


t4 


700 or 4C0 


Branch 




BSI 




400 


Branch and Store Instruction Counter 




BSC 




480 


Branch or Skip Conditionally 




BP 


t6 


4C30 


Branch Accumulator Positive 




BNP 


t6 


4C03 


Branch Accumulator Not Positive 




BN 


+6 


4C28 


Branch Accumulator Negative 




BNN 


■to 


4C10 


Branch Accumulator Not Negative 




BZ 


+6 


4C18 


Branch Accumulator Zero 




BNZ 


t6 


4C20 


Branch Accumulator Not Zeo 




BC 


t6 


4C02 


Branch on Carry 




BO 


t6 


4C0I 


Branch on Overflow 




BOD 


t6 


4C04 


Branch Accumulator Odd 




SKP* 


t 


480 


Skip on Condition(s) 




BOSC 


2 


484 


Branch Out or Skip Conditicnally 




MDX 




700 


Modify Index and Skip 




Shift 










SLA* 




100 


Shift Left Accumulator 




SLT* 




108 


Shift Left Accumulator and Extension 




SLC* 




10C 


Shift Left and Count Accumulator and Extens 


on 


SLCA* 




104 


Shift Left and Count Accumulator 




SRA* 




180 


; Shift Right Accumulator 




SRT* 




188 


Shift Right Accumulator and Extension 




RTE* 




18C 


Rotate Right 




XCH* 


+3 


18D 


Exchange Accumulator and Extension 




Input/Output 








XIO 




080 


Execute I/O 




3 
Miscellaneous 








NOP* 




100 


No Operation 




WAIT* 




300 


Wait 





I 



*Valid in short format only 

tNot included in card/paper tape Assembler or DMT Assembler. 

1 . The hexadecimal representation of the machine operation code is derived from the instruction format in the manner shown below. 
Bits 6 and 7 are assumed to be zeros because they do not enter into the makeup of any operation codes. 

2. Same as BSC with Bit 9 set to one . 

3. An operand should not be specified. 

4. When branch is short (Blank or X format), this operation code is assembled cs an MDX (700). If the branch is long (L or I format), 
this operation code is assembled as a BSC with Bit 5 set to one (4C0). 

5. This instruction is automatically assembled as a long instruction (L is not required in the format field). Note that an attempt to use 
indirect addressing will result in a syntax error. Indexing is not permitted with this extended operation code. 

6. Extended conditional branch operation codes are assembled automatically as long instructions. ( L is not required in the format field). 
Note that the proper condition code bits are preset, and further condition bits may not be specified following the operand. 

Hexadecimal Characters 



OP Code - 



Format (F)- 



I I I I 1 I I I I I II I I I I 1 

8 9 JO 11 12 13 14 15; 



12 3 4 5 



Index Tag bits (T)- 



n it 



IA bit, part of 
displacement, or extension 
of OP code 



Part of displacement, 
or extension of OP code 

Condition indicators, 
or part of displacement — 
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ADDITIONAL MONITOR SYSTEM MNEMONICS (DM2) 

Several new mnemonic operation codes which are 
equivalent to a Branch or Skip on Condition (i3SC) may 
be used with the DM2 System. The operation code 
to be used for a specific job depends on the format 
and condition code required . 

A new mnemonic MDM has been introduced that 
may be used in place of an unindexed MDX long. 
XCH may be used in place of RTE 16. 

Examples of the additional DM2 System 
mnemonics are shown in Table 2 . The mnemonics 
are listed below. 

Skip on Condition (SKP) . The condition codes (+, -, 
Z, E, O, and C) are specified as with a shori BSC 
instruction. This instruction must not be indexed. 

Branch Unconditionally (B) . If the Format field con- 
tains an L or I, the BSC operation code is used with 
bit 5 set to one. Condition codes are not allowed 
after the address expression in the Operand field. 
If the Format field is left blank or contains an X, 
the MDX operation code is used, and the expression 
in the Operand field is used to form the displacement. 

Branch Accumulator Positive (BP) . Condition codes 
for accumulator zero (Z) and accumulator negative 
(-) are set to one. 

Branch Accumulator Not Positive (BNP) . Condition 
code for accumulator positive (+) is set to one. 



Branch Accumulator Negative (BN), Condition codes 
for accumulator zero (Z) and accumulator positive 
(+) are set to one. 



Branch Accumulator Not Negative (BNN) . Condition 
code for accumulator negative (-) is set to one. 



Branch Accumulator Zero (BZ). Condition codes for 
accumulator positive (+) and accumulator negative 
(-) are set to one. 

Branch Accumulator Not Zero (BNZ). Condition code 
for accumulator zero (Z) is set to one. 

Branch on Carry (BC) . Condition code for Carry 
indicator off (C) is set to one. 

Branch on Overflow (BO) . Condition code for Over- 
flow indicator off (O) is set to one. 

Branch Accumulator Odd (BOD) . Condition code for 
accumulator even (E) is set to one. 

NOTE: Condition codes may not be used with any of 
the above instructions, except SKP, since the condi- 
tion code is implicit in the extended mnemonic. The 
conditional branch instructions (all except SKP and 
B) are always assembled as long instructions; thus, 
the Format field need not contain an L, although the 
instruction is not classed as an error if L is speci- 
fied. Indirect addressing may be specified. 



Modify Memory (MDM). Contents of the location 
specified by the first operand is incremented or 
decremented by the value of the second operand. The 
second operand must be in the range -128 to +127. 

NOTE: This instruction is always assembled as a 
long instruction; thus, the Format field need not 
contain an L, although the instruction is not classed 
as an error if L is specified. Indexing and indirect 
addressing must not be specified. If the operand 
becomes zero or changes sign, the next word in the 
program will be skipped. 

Exchange Accumulator and Extension (XCH). Ex- 
change is identical to a RTE of 16. No operand is 
specified with this instruction. 
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Table 2. Examples of New (Extended) Machine Instruction Mnemonics (DM2 only) 



New Instruction Statements 



5-A7? 



SKP, 



SJ<L& 



SAR 



ULR 



2. 



!££- 



jig A/i/K/ i — 



5.*!^ 



S_^. 



S£. 



£/^ 



e\NJz-\ 



ZAL 



SA^ 



!££. 



jAi. 



Al 



Afi. 



2L<a£ 



^&£& 



i^Litt 



Ifl. M . 



£££ 



iz. 



|z* 



i a. 



/•■-, 



Zl_L_L. 



fil-L. 



i£_u 



H->C 



Ifi X ZTTL 



\AslLEtL_ 



m£J^A. 



XB&TA 



§-X,£,Tj4, 



KiTiMA 



l^nMS- 



-i|5li 



■ 5JL&L 



MSJL&&- 



EMT&-hli 



t 






&d.i£J;\ 



ISiAvAj 



\Alma 



Axy-aZ 



JH QiSiCLi 



Equivalent Statements 

: : S| 27 



Bi fffl 



ESC 



| g;5.£ 



|;//2>,y, 




KJ.g 



£££ 



1: 



£s£ 






S££ 



£££ 



fiX£ 



£££ 



£££ 



jflAX 



I flax 



iM,x. 



177^ 



._ j-jS .fa. _ _ Si-j: £ hfci' »***! / It - 



IZ 



1L 



i£ 



^1 



*=* 



a. 



£_ 



+iT.gi. i . 

_L_1_ J__l_ 



_ ;iliS /hkm\r\ fTL- 



11 



l&IMAi+M, 



j i i_ j i_ 



J 1 L_J 1_ 



aiu'j j_ 



_1 I L. J L 



ttTAjZ 



_L_1 LJ L 



Sj&T^jZj 



_1 I LJ L 



KiTiNtSt j i 



sax®, z 



StUi&'fiif iZi— i 



mSdi>S&i>*+ 



_l 1 L_l L 



lEJLU&LL 



&-*£- 



_l 1 L_l L 



A^ 



$\ff\F\l- 1 jt£\ 



§£AiAA^ 



J I I I L 



{/iLhlAjLy 



%I^zJLZ^ 



I l I I L 



XLL- 



Operations Performed 

Skip if accumulator is positive 

Skip if accumulator is non-zero 

Skip if accumulator is zero 

Skip if Overflow indicator is off 

Skip if Carry indicator is off 

Skip if accumulator is non-zero or if Carry indicator is off 

Branch unconditionally to EXIT, where EXIT must be within normal 
displacement range. 

Branch unconditionally to ALPH 

Branch to BETA if accumulator is zero 

Branch to BETA if accumulator is negative 

Branch indirectly to BETA (i.e., the address specified by contents of 
BETA) if accumulator is non-zero 

Branch to RTNA if accumulator is negative 

Branch to RTNB if accumulator is non-negative (zero or positive) 

Branch to SUB@ if accumulator is positive 

Branch indirectly to SUB$ (i.e., the address specif ied by the contents of 
SUB$) if accumulator is positive 

Branch to SUB* if accumulator is non-positive (zero or negative) 

Branch to ENTR+1 if Carry indicator is on 

Branch indirectly to address specified by contents of index register 1 
if Carry indicator is on 



Branch to oddress specified by contents of index register 2 plus 5 if 
Overflow indicator is on 



Branch to $AFE if accumulator is odd 
Increment contents of core location SAVA by 5 
Increment contents of core location/1D6A by 100 decimal 
Decrement contents of core location A by 12 
Exchange the accumulator and extension (rotate right 16) 



I 
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ASSEMBLER INSTRUCTIONS 



Just as machine instructions are requests to the 
computer to perform a sequence of operations during 
program execution, assembler instructions are 
requests to the Assembler to perform certain opera- 
tions during the assembly. In contrast to machine - 
instruction statements, assembler-instruction state- 
ments do not always cause machine instructions to 
be included in the assembled program. Some, such 
as BSS and BES, generate no instructions but do 
cause storage areas to be set aside for constants and 
other data. Others (e.g., EQU) are effective only 
during the assembly; they may or may not generate 
something in the assembled program. If nothing is 
generated, the Location Assignment Counter is not 
affected. 

The following is a list of all assembler statements 
permitted by the IBM 1130 Card/ Paper Tape Assembler. 
These statements are also valid for the Monitor 
Assembler. Additional statements are provided for 
the Monitor Assembler and are listed in the section 
Monitor Assembler Statements. 
Program Control 

ABS - Absolute Assembly 

LIBR - Transfer Vector Subroutine 

SPR - Standard Precision 

EPR - Extended Precision 

ORG - Define Origin 

END - End of Source Program 

Data Definition 

DC - Define Constant 

DEC - Decimal Data 

XFLC - Extended Floating Constant 

EBC - Extended Binary Coded Information 

Storage Allocation 

BSS - Block Started by Symbol 

BES - Block Ended by Symbol 

Symbol Definition 

EQU - Equate Symbol 

Program Linking 

ENT - Define Subroutine Entry Point 

ISS - Define Interrupt Service Entry Point 

ILS - Define Interrupt Level Subroutine 

CALL - Call Subroutine (2-word call) 

LIBF - Call Subroutine (1-word call) 

PROGRAM CONTROL STATEMENTS 

Program control statements are used to set the Lo- 
cation Assignment Counter to a specific value, to 
define the end of a source program, or to specify 
whether a particular program is to be assembled as 
absolute or relocatable. None of these assembler 
statements generate machine-language instructions 
or constants in the object program. 



ABS — Assemble Absolute 

An ABS statement is used to specify that a main pro- 
gram is to be assembled as an absolute program. 
An absolute program is one in which the core loca- 
tions used at execute time are the same as those 
specified by the programmer in the source program. 
The ABS statement is punched as shown below and 
is then used as the first statement of a source pro- 
gram. 



Label 
21 25 




Operation 

27 30 




F 
32 


T 

33 




35 40 45 






A.B.S, 












1 1 1 1 




i i i 










1 1 1 1 1 1 1 1 1 1 1 1 1 I 



If the first (non-comment) statement of a source pro- 
gram is not an ABS statement, the program will be 
assembled as relocatable. In an absolute assembly 
headed by an ABS statement, all symbols and aster- 
isk values are defined as absolute quantities; there- 
fore, no relocation errors are possible. The 
significance of relocatable and absolute assemblies 
is explained in the following paragraphs. 

Relocatable Assembly 

Some programs assembled by the IBM 1130 Assem- 
bler are absolute; that is, the locations of assembled 
instructions are known during the assembly and the lo- 
cation on the listing is the actual location where a 
particular word is loaded. However, subroutines 
used by an absolute program must be in such a form 
that they may be loaded at various locations; other- 
wise, it would be necessary for the user to reassem- 
ble the subroutines each time he assembled a main 
program that required them. Therefore, all subrou- 
tines must be and main programs may be assembled 
relocatable. 

Every relocatable program or subroutine pro- 
duced by the IBM 1130 Assembler is assembled as 
though it begins at location zero. Since a job to be 
executed may contain several subroutines, it is 
obvious that they cannot all be loaded into locations 
starting with location zero. In fact, no relocatable 
program is ever loaded at location zero; instead, 
each program is relocated. The relocatable main 
program is loaded into the first available location. 
Subroutines are then loaded into successively higher 
locations of core storage, each beginning with the 
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next even location after the last core storage 
location used by the preceding subroutine. When 
a particular program has been loaded, the address 
of the first word is called the load address for 
that program. 

Thus, the address in core storage actually oc- 
cupied by an instruction of the program is the address 
assigned to that instruction during assembly, plus 
the load address of that program. To keep the pro- 
gram self-consistent, the load address must be add- 
ed to the address of many (but not all) 2 -word in- 
structions, and those constants whose values are 
relocatable. 

This process of conditionally adding the load 
address is performed by the loading program before 
execution and is called relocation. In relocating in- 
structions, the loading program is guided by relo- 
cation indicator bits which are a part of the object 
program. 



If used, the SPR or EPR statement must follow 
the ABS or LIBR statement. If no ABS or LIBR 
statement is used, the SPR or EPR statement is the 
first statement in the program. 

ORG — Define Origin 

This assembler instruction is used to set the Location 
Assignment Counter (i.e. , the next location to be 
assigned) to any desired value. In this way the pro- 
grammer is able to control the assignment of storage 
to instructions, constants, and data. If a Define 
Origin statement is not the first entry in an absolute 
source program, the processor begins the assign- 
ment of storage at a location compatible with the size 
of the applicable loader (Card/Paper Tape Assem- 
bler) or the version of disk I/O required (Disk 
Monitor Assembler). A typical Define Origin state- 
ment is shown below. 



Absolute Assembly 



The programmer uses the ORG assembler statement 
in his source program to specify the locations into 
which the object program resulting from an 
absolute assembly is loaded. Subroutines are 
loaded into successively higher even-core locations 
following the end of the main program. 

Only main programs may be assembled absolute; 
subroutines must be assembled relocatable. 

LIBR — Transfer Vector Subroutine 

An LIBR statement is used as the first statement of 
a subroutine to specify that the subroutine is to be 
called by LIBF statements only (see Program- 
Linking Statements ). The absence of an LIBR state- 
ment specifies that the subroutine is to be called by 
CALL statements only. LIBR statements are for sub- 
routines only, as ABS statements are for main pro- 
grams only. An LIBR statement needs no operands. 

SPR - Standard Precision, EPR - Extended 
Precision 



The SPR or EPR statement specifies that the pro- 
gram (main or subroutine) in which it appears uses 
standard precision or extended precision, respec- 
tively, for arithmetic operations. If these state- 
ments are included in the user's programs, the 
loader ensures that main programs and subroutines 
always match with regard to precision. Their use 
is optional, however. 



Lob.1 
21 23 




Operation 

27 30 




F 

32 


T 
31 




35 40 43 






0,R,G> 










3,0,0,0, ,•>... i •• ■ 


1 l 1 l 




■ i i 










i • i i i i i i i i i i i. j_ 



The label, if used, is assigned a value equal to the 
value of the Location Assignment Counter at the time 
the statement is encountered in the source program. 
(This assignment is made before the counter is 
modified.) If any symbols are used in the expression, 
they must have been previously defined. In a relo- 
catable assembly, an absolute expression in the oper- 
and field is considered a relocation error and the 
statement is ignored. 

Some examples of Define Origin statements are 
given below: 



Lob.1 

21 23 




Operation 

27 30 




F 

32 


T 
33 




Op., 

35 40 4.1 50 






0,R6, 










Xi Hi Z, , , ■ 






, 












S.T,A,G,T 




O./C.G, 










X.4.Z.-f.5,<5. ,,...,..,. 






■ i i 










■ i i i i i i i i i ■ i i i i i 


sj^.e.r 




Ofi,G, 










#i+.5.0, .L.O.C, .C.T.R.+.ff.d. , 


i i i i 




i i i 










■ i i i i i i i i i i i i i i i 



If the label XYZ has been previously defined as 
1000 10 tne first entry directs the assembler to begin 
the assignment of succeeding entries at location 1000. 
The second entry directs the Assembler to begin the 
assignment of succeeding entries 50 core locations 
beyond the location that has been assigned to the 
symbol XYZ. The third entry directs the Assembler 
to begin the assignment of succeeding entries at the 
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address specified by the current address of the Lo- 
cation Assignment Counter plus 50. 

END — End of Sour ce Program 

An END statement is the last statement of a source 
program; it indicates to the assembler that all state- 
ments of the source program have been processed. 
An END statement is also used to define the execution 
address of the main program. To do this, the END 
statement requires an operand that represents the 
starting address of the program. At the completion 
of loading, execution begins at the address specified 
by the operand. For subroutines, all entry points 
are specified by ENT statements (described later); 
therefore, the operand of the END statement for a 
subroutine is blank. 

The following statements illustrate both types of 
END statements. 



Label 

21 25 




Operation 

27 30 




F 

32 


T 

33 




OperarK 

J5 40 45 50 


H.6.X. , 




AC, 












AF,F,F,F, >H,E,X, ,C,0,A/,S,T, , , 


■ i i i 




















D,E,C, , 




P.c, 












-•3 


8,5, ,D,B,C, ,l,M.T,6.e.R, . . 






















A.L,P,H,A 




o,c, 












.i5 


■_.±£Aditf. L.Ci0|A/|S L fi i ijli 






, , 
















A.D,D.ie,S 




P.C, 












A, I 


PidiAx+lS, ,A &£>,&, iCtOtA/f , 


■ i i i 




1 1 














l I l JL I I . 1 I 1 l i l i l. i 



DEC — Decimal Data 

The Decimal Data statement is used to enter binary 
data, expressed in decimal form, into a program. 
One DEC statement generates two 16 -bit words of 
binary information. The format of the DEC statement 
is as follows: 



Label 
21 25 




Operation 
27 30 




F 

32 


T 

33 




OptH 
35 40 45 50 






E.M.D. 










.E.N.D. ,0.F. .P,R.O*G.R.flM . 
















■ i i i i i i i i i i i i i i ■ 






f.A/,0. 










6.0. ,3,e i A,A/,C.ti> ,T/>, .6.0 , , 


• ill 




■ i i 










i i i i i i i i i i ■ i ii J....J. 



DATA DEFINITION STATEMENTS 

Data Definition statements are used to enter data con- 
stants into storage. The statements can be named by 
symbols so that other program statements can refer 
to the fields generated. Any type of data definition 
statement can be used in standard or extended pre- 
cision program. 

DC — Define Constant 

The Define Constant statement is for generating con- 
stant data in main storage. Data can be specified as 
characters, hexadecimal numbers, decimal numbers , 
storage addresses, or any valid expression. One 16- 
bit word is generated for each DC statement. The 
format of this statement is shown below: 



L.A.B.E.L 



Operatic 



P,£,C, 1 



Operands & Rei 



D.e.c JmaJ, ,fl,«t .t«. ,/.t 1 g^.. J 



If a label is used, its value is equal to the current 
value of the Location Assignment Counter if the cur- 
rent value is even; if the current value is odd, the 
label will be equal to the current value plus one. The 
label is assigned to the leftmost word of the generated 
constant. The types of data permitted in the operand 
field are described in the paragraphs entitled Decimal 
Data Items . An example of a DEC statement follows: 



Label 

21 25 




Operation 

27 30 




F 

32 


T 

33 




35 40 45 


D.A.T.A, 




d.e.c. 










~h. 1 9 i ^_i 


iii i 




■ i i 










1 1 I 1 ill L. -1-1 1 1_ A — 1__ 



If the value of the Location Assignment Counter is 
1000 when the DEC statement is encountered, the two 
words in storage look like this: 



Label 

21 25 




Operation 

27 30 




F 

32 


T 
33 




35 40 45 


L.A.g.C.L 




P.C. . 










/J.AA ,ex.PA.e.s.s./ t oM. . 


1 1 1 1 














1 I •• 1 ■ 1 1 1 1 1 1 1 1 _ 



If a label is used, the address assigned to it is the 
location of the generated data word and is equal to 
the current value of the Location Assignment Counter. 
Some examples of DC statements follow: 



Location 



01000 
01001 



Contents in Hexadecimal Form 

0000 
0013 



Decimal Data Items 

A decimal data item is used to specify, in decimal 
form, two or three words of data to be converted into 
binary form. Decimal data items are used in the 
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operand field of DEC assembler statements. Three 
types of decimal -data items are permitted: decimal 
integers, real numbers, and fixed-point numbers. 
A real decimal-data item can also be used as the 
operand of an XFLC statement that generates a 
3 -word constant. 

Decimal Integers . A decimal integer is composed of 
a series of numeric digits with or without a preceding 
plus or minus sign. The allowable range of decimal 
integers is ~(231-l) to 23!-l. 



Word 1 

4800 



Word 2 
0083 



Examples 



Decimal Integer 
50 
1535 
-3729 



Stored As 

00000032i 6 

OOOOOSFT? 



FFFFF16F 



(2's complement) 



Real Numbers. A real number has two components: 
a mantissa and an exponent. 

• Mantissa — The mantissa is a signed or unsigned 
decimal number , which can be written with or 
without a decimal point. The decimal point can 
appear at the beginning, at the end, or within 
the decimal number. If the exponent (see below) 
is present, the decimal point can be omitted, 

in which case it is assumed to be located at the 
right-hand end of the decimal number. 

• Exponent — The exponent consists of the letter 
E, followed by a signed or unsigned decimal in- 
teger. The exponent part can be omitted if the 
mantissa contains a decimal point. IE used, 

it must follow the mantissa. 



A real number is converted to a normalized, real 
binary number. The exponent part, if present, 
specifies a power of ten by which the mantissa is 
multiplied during conversion. For example, all of 
the following real numbers are equivalent and will be 
converted to the same real binary number. 

4.500 
45.00E-1 
4500E-3 
.4500E1 



The DEC assembler instruction stores real 
numbers in the standard precision real number 
format described in the system subroutine library 
manual. 

Fixed Point Numbers . A fixed -point number can 
have up to three components: a mantissa, an exponent, 
and a binary-point identifier . 

• Mantissa - The mantissa is the same as describ- 
ed for real numbers. 

• Exponent - The exponent is the same as describ- 
ed for real numbers. 



• Binary-Point Identifier — This identifier consists 
of the letter B, followed by a signed or unsigned 
decimal integer . The binary-point identifier 
must be present in a fixed-point number and 
must come after the mantissa. If the number has 
an exponent, the binary point identifier may 
precede or follow the exponent. 

A fixed-point number is converted to a fixed- 
point binary number that contains an understood binary 
point. The purpose of the binary-point identifier of 
the number is to specify the location of this under- 
stood binary point within the word. The number that 
follows the letter B specifies the number of binary 
places in the word to the left of the binary point (that 
is , the number of integral places in the word) . The 
sign bit is not counted. Thus, a binary-point identi- 
fier of zero specifies a 31 -bit binary fraction. B2 
specifies two integral places and 29 fractional places . 
B31 specifies a binary integer. B-2 specifies a binary 
point located two places to the left of the leftmost bit 
of the word; that is, the word would contain the low- 
order 31 bits of binary fraction. As with real 
numbers, the exponent, if present, specifies a 
power of ten by which the mantissa is multiplied during 
conversion. 

A fixed-point number preceded by a minus sign 
is stored in 2's complement form. 

The following fixed-point numbers all specify the 
same configuration of bits, but not all of them specify 
the same location for the understood binary point: 



In standard precision, the above real numbers are 
converted and stored in two consecutive storage 
locations as follows: 



22.5B5 

11.25B4 

1125B4E-2 



20 



1125E-2B4 
9B7E1 

All of the above fixed-point numbers are con- 
verted to the same binary configuration, whose 
hexadecimal representation is: 



Word 1 
5A00 



Word 2 
0000 



XFLC - Extended Real Constant 

The XFLC assembler instruction is used to introduce 
into a program an extended precision real constant, 
expressed in three consecutive data words. When 
assembled, this instruction produces a format 
identical to the extended range real format describ- 
ed in the system subroutine library manual. 

The format of the XFLC instruction is shown 
below: 



LA&gjM 



Operatic 



X.F.L.C 



Operands & Rer 



R.E.A.L. .N.UMB.E.R* 



-i j i i i_ 



_i i i i i i i i i_ 



The label is optional; if it is used, it is assigned to 
the location of the leftmost word generated. 

Some examples of the XFLC instruction are 
shown below: 



Label 

21 25 


$& 


Operation 

27 30 




F 

32 


T 

33 


W 


Operands & Ret 

35 40 45 50 


1 1 i I 




X.F.L.C 










0... 5.3.1. 2.5 


1 1 1 I 
















R,£,A,L, 




X.F.L.C 










-,0... 5,3,1,2,^ 


■ i i i 




i i i 










!,,,,,,,, I.i, 


i i i i 




X.F.LC 










S,.J,Z.£,2 


i . , , 


Zi 


i i i 


*! 






: : : : : : : 


— 1 1 1 1 1 1 1 1 1 1 1 L-_l 1 1 1 1 1 1_ 



The data (in hexadecimal form) generated by each of 
these examples is 



1. 


Word 1 


Word 2 


Word 3 




0080 


4400 


0000 


2. 


Word 1 


Word 2 


Word 3 




0080 


BC00 


0000 


3. 


Word 1 


Word 2 


Word 3 



EBC — Extended Binary Coded Information 

The EBC statement is used to generate data words, 
each consisting of two 8-bit characters in the Extend- 
ed BCD Interchange Code (see Appendix A ). Up to 18 
sixteen-bit words can be generated with one EBC 
statement. The format of the statement is shown 
below: 



Label 

21 25 




Operation 

27 30 




F 
32 


T 
33 




35 40 45 


l.A.B.t. 




E.B.c, 










.tA.L.P.d.Ai .0.A.T.A,.. . , 


i i i i 




1 1 1 










i i i i i i i i i i i i i i 



If a label is present, it is assigned to the location of 
the leftmost word generated. The operand field con- 
tains the alphameric data to be represented in stor- 
age. This data must begin and end with a period. 
The data can be any valid character in the Extended 
BCD Interchange Code, including the period. 

Examples 



Label 

21 25 




Operation 

27 30 




F 
32 


T 

33 




35 40 45 


C,0,A/.S,7 




£,B,C, 












■ i i ■ 
















A,L,P,H,A 




E,8,C, 










. l Cfl i ltf,S l T l A l N l T 


■ i i i 




i i i 










— i — 1_ i i i i i i i i i i i i 



The first example generates three words of data, with 
the location of the label CONST assigned to the left- 
most location of the first word generated. 



CONST- 



Word 1 
C5D9 

J 



Word 2 
D9D6 



Word 3 
D940 



Note that if the constant has an odd number of char- 
acters, as in the above example, the last word of 
data ends with the 8 -bit equivalent of blank. 

The second example generates four words of 
data: 



Word 1 
C3D6 



Word 2 
D5E2 



Word 3 
E3C1 



Word 4 
D5E3 



008 A 



4000 



0000 



NOTE: A period may not appear in the remarks 
field of an EBC instruction. 
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STORAGE ALLOCATION STATEMENTS 

Storage allocation statements are used to reserve 
blocks of storage for data or work areas . Two such 
statements are available with the IBM 1130 Assem- 
bler: Block Started by Symbol and Block Ended by 
Symbol. 

BSS — Block Started by Symbol 

The BSS assembler instruction is used to reserve an 
area of core storage, within a program, for data 
storage or for working space. The format of the 
BSS instruction follows : 



L t A,A£M 



Ope rat i< 



flS.S, 



Operandi & Rii 



§A6,s,oJ,u,t,e. .f.x. p.Kcs.s./.o/i, 



-I I 1 L—J L. 



The expression specifies the number of words to be 
reserved; the label, if specified, refers to the left- 
most word reserved. The location of the block of 
storage within the object program is determined by 
the location of the BSS statement within the source 
program . 

If the character E is punched in column 32, the 
assembler assigns the leftmost word of the reserved 
location to the next available even location. If a 
blank or any character other than E appears in 
column 32, the assembler assigns the leftmost word 
of the reserved area to the next available location 
regardless of whether that location is even or odd. 
This feature is useful when defining areas for use 
with double precision instructions . 

A BSS statement with an E format and an oper- 
and value of zero causes the Location Assignment 
Counter to be made even (if necessary) before the 
next instruction is assembled. 

A BSS instruction causes an area to be reserved, 
not cleared; therefore, it should not be assumed 
that an area reserved by a BSS instruction contains 
zeros. 

Any symbols in the operand field of a BSS assem- 
bler instruction must have been previously defined. 
The expression in the operand field must be an 
absolute expression. 

In the following example, the symbol AREA is 
equivalent to 3000; the next location assigned is 
3028. 



Labol 

21 25 




Operation 

27 30 




F 
32 


T 

33 




35 40 45 






o,e,G, 










3i0,0i0, i i i i i i i i i i 


A.ft.E.A. 




B.S.S, 












• iii 




1 1 1 










i ■ i i i i i i i i i i i i 



BES — Block Ended by Symbol 

The BES instruction is identical to the BSS instruc- 
tion except that the address assigned to the label is 
the rightmost word in the area plus 1, i.e. , the 
next location available for assignment. 

In the previous example , the symbol AREA is 
equivalent to 3028. 



SYMBOL DEFINITION STATEMENT 

One symbol definition statement (EQU) is available in 
the IBM 1130 Assembler language. 

EQU — Equate Symbol 

The EQU statement is used to assign to a symbol a 
value other than the value of the Location Assignment 
Counter at the time the symbol is encountered. The 
format of the EQU statement is 



S.YMB.L 



Ope ratio 



\ EQM 



Operands & Ret 



/<./?, ,<f>/>./-,es,.g,/.o,/r, 



The symbol in the label field is made equivalent to 
the value of the expression. The expression may be 
absolute or relocatable. All symbols appearing in 
this expression must have appeared as a label in a 
previous statement. If an asterisk (*) is used as the 
expression, the value assigned to it is the next loca- 
tion to be assigned by the assembler. 

Examples 



Label 
21 25 




Operation 

27 30 




F 
32 


T 
33 




35 40 45 


N.AM.e. 




<f.«.«v. 










ZtV, i i i ■ i i i | | , | | 


1 1 1 I 
















L.O.O.P, 




£.<k.U. 










A/iAi«,CiT,/i '• 1 1 1 1 I I 


- • i i ■ 




i i i 










— ■ — 1 — 1 — 1 1 1 1 1 1 1 1 1 1 1 
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In the first example, the symbol NAME is assigned a 
value of 26. In the second example, the symbol 
LOOP is assigned a value of 27. 



LINKING STATEMENTS 

Linking statements are used to establish communi- 
cation between a main program and its subroutines 
or between a program and the 'Monitor system. 



ENT - Define Subroutine Entry Point 

The ENT statement should be used to define the 
entry point(s) in all subroutines except ISS and ILS. 
Up to fourteen entry points (ten with the Card/Paper 
Tape Assembler) may be defined for each subroutine 
(this would require an equal amount of ENT state- 
ments). The format of the ENT statement is shown 
below. 



21 


Label 


25 




Operation 1:1; 
27 30 |:j 


Si 32 


T 

33 




35 


40 


1 1 1 1 




t.NJ, [• J 






N.A.M.E, , , 


■ ■li 












1111 




_i_ j — i lm 






— L....1 1 1 1 1 



NAME is a symbol that identifies an entry point for 
the associated subroutine. This symbol must be 
relocatable. All ENT statements for a given sub- 
routine must be together and must precede all state- 
ments except LIBR, SPR, EPR, and comments 
statements. ENT, ISS, or ILS statements (see 
below) may not be used in the same subroutine. 



ISS - Define Interrupt Servic e Entiy Point 

IBM provides interrupt service subroutines (ISS) for 
all devices ; however, the user is given the option of 
replacing or adding to these subroutines with his own. 
The ISS statement is used to define an entry point in 
an interrupt service subroutine and to establish 
interrupt linkages to the subroutine during loading. 
Only one entry point may be defined for each sub- 
routine. The format of the ISS statement is shown 
below. 



Label 
21 25 




Operation 

27 30 




F 

32 


T 

33 




35 40 45 


1 1 1 1 




I.S.S, 




N 


N 




Ai t MtMiC. , ,L.i , , 


III! 




1 1 1 










__i — i_i i i ■ i i i i i i i 



Word 30 of the header record can be set for 
identification purposes as shown below. Word 30 is 
not used by any of the 1130 programs. 



Label 

blank 

1130 

1800 



ISS Header Word 30 

blank 

1 

2 



NAME is as described for the ENT statement and 
NN (the ISS number) is a decimal number from 01 to 
20 used during loading to establish the linkage from 
the appropriate point in the corresponding ILS. The 
numbers and associated devices used in the sub- 
routines provided by IBM are listed below. 

Card/Paper Tape System and DM1 System 



Number* 

01 
02 

— Q3 ■-_ 

05 
06 

07 
08 



Device or Function 



1442 Card Read Punch 

Input Keyboard/ Console Printer 

,1134 Pape r Tape Reader ; 

UIE5, Paper Tape Punch 

Single Disk Storage 

1132 Printer 

1627 Plotter 

Synchronous Communications Adapter 



*Numbers 09 through 20 are assignable by the user. 



DM2 System 



r — ^ 

f Number*/ 


Device or Function 


01 


1442 Card Read Punch; 




i 144 2 Card Punch _. 


02 


Input Keyboard/ Console Printer 


*-©3 


1134 Paper Tape Reader; 




1&55 Paper Tape Punch 


04 


2^1_CardLReader 


05 


Single Disk Storage; 




2310 Disk Storage 


06 


1132 Printer 


07 


1627 Plotter 


08 


Synchronous Communications 




Adaptor 


09 


1403 Printer 


10 


1231 Optical Mark Page Reader 



*Numbers 11 through 20 are assignable by the user. 

NOTE: User-assigned ISS numbers should start at 
twenty and proceed backwards in order to avoid con- 
flict with IBM-assigned ISS numbers. 
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L is a one-digit number required by the Card/Paper 
Tape Assembler to indicate the interrupt level(s) 
associated with the subroutine. The level numbers 
(0-5) can be listed in any order in columns 45, 50, 
55, 60, 65, and 70 with the first appearing in 45, 
the second in 50, etc. 

L is not used with the monitor system. Instead, 
LEVEL control cards are used with the subroutine 
being assembled, one card per interrupt level re- 
quired (see the monitor system operator's manual). 

An ISS statement must precede all statements 
except LIBR, SPR, EPR and comments statements. 

Procedures for writing ISSs are provided in the 
subroutine library manual for the Card/Paper Tape 
and DM2 systems and in the operator's manual for 
the DM2 system. 



ILS - Define Interrupt Level Subroutine 

IBM provides interrupt level subroutines for the 
various I/O devices and their associated interrupt 
levels; however, the user may replace or add to 
these subroutines with his own. The ILS statement 
is used to define an interrupt level subroutine and to 
associate the subroutine with a specific interrupt 
level. The format of the ILS statement is shown 
below. 



Interrupt Level 



Device(s) 



Label 

21 25 




Operation 

27 30 


- 


F 

32 


T 

33 


1 


35 






/.Z.,5, 




N 


N 




1 1 


1 I 1 I 




■ i i 










1 1 



NN is the interrupt level number (00-05) associated 
with the interrupt level subroutine and is used during 
loading. The devices associated with each interrupt 
level are shown below: 



Interrupt Level 
00 
01 
02 



Device(s) 

1442 Card Read Punch 
(1442 Card Punch) 
1132 Printer, Synchronous 
Communications Adaptor 
Single Disk Storage (2310 
Disk Storage) 



03 


1627 Plotter 


04 


Key board/ Console Printer, 




1442 Card Read Punch, 




1134 Paper Tape Reader, 




1055 Paper Tape Punch 




(2501 Card Reader, 




1403 Printer, 1231 Optical 




Mark Page Reader) 


05 


PROGRAM STOP Key or 




Interrupt Run Mode, 



NOTES: 1. The devices listed in parentheses are 
used with the DM2 system only. 
2. An ILS statement must precede all statements 
except SPR, EPR, and comments statements. 
Procedures for writing interrupt level sub- 
routines are provided in the subroutine library 
manual for the Card/Paper Tape and DM1 systems 
and in the operator's manual for the DM2 system. 



CALL - Call Direct Reference Subroutine 

A CALL statement is used to call some of the sub- 
routines in the IBM Subroutine Library or any user- 
written subroutine written for the CALL statement. 
During execution, this type of call takes the form 
of a long (two-word) BSI (direct for card/paper 
tape system, indirect for Monitor system), to the 
entry point named in the CALL and the correspond- 
ing ENT or ISS statement. 

When BSI is executed, the location of the first 
word following it is placed in the entry point loca- 
tion, and control is transferred to the first word 
following the entry point. The format of the CALL 
statement is: 



Label 




Operation 

30 


1 


F 

j? 


T 




35 « 


L.A.B.E.L 


II 


C,AL,L 


'■■'.<■■ 








M.AME, , , 




|| 












i i i i i i 


i i. i i 




, 1 J I 


1 








i i i i i i 



If used, the label is assigned to the current 
value of the Location Assignment Counter, which 
is the same as the leftmost word of the generated 
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BSI instruction. The name of the called subroutine 
is assembled into the object program, together with 
a unique code identifying the CALL. This code is 
used during loading to generate the BSI to this sub- 
routine. 



LIBF - Call TV (Transfer Vector) Reference 
Subroutine 



Recognizing the Subroutine Call. All subroutines 
that utilize the Transfer Vector are called via 
LIBF statements. These statements take the fol- 
lowing general form: 



LIBF 


NAME 


DC 


Parameter 


DC 


Parameter 


etc. 





An LIBF statement is used to call any of the sub- 
routines in the Subroutine Library (or any user- 
written subroutine) written to utilize the Transfer 
Vector (see the following section). The format 
of the LIBF statement is: 



Operation 



L.A.B.E. Lf JL.I.B.F 



J i i i j i_ 



If used, the label is assigned to the current value of 
the Location Assignment Counter when the LIBF 
statement is encountered. The name of the called 
subroutine is assembled into the object program, 
together with a unique code identifying the call as an 
LIBF call. This code is used during loading to 
generate the linkage to the subroutine. During exe- 
cution, the TV subroutine uses Index Register 3. 
Therefore, if Index Register 3 is used by any other 
instruction in the user's program, it must be saved 
and restored before it is needed by any TV subroutine 
calls. 



LIBF Subroutine Transfer Vector 

To fully understand the use of the LIBF statement, 
the user should be familiar with the makeup of the 
transfer vector, which allows main programs to 
communicate with relocatable subroutines (and re- 
locatable subroutines to communicate with each 
other) without knowing where in core storage the 
subroutines are loaded. The Transfer Vector con- 
sists of three 16-bit words for each subroutine entry 
point referred to by an LIBF statement. The contents 
of the three words vary as the subroutine goes through 
the three phases of being called, loaded, and execut- 
ed. The following paragraphs describe these three 
phases, and illustrate the contents of the transfer 
vector for each phase. 



When an LIBF call is recognized during the loading 
of an object program, the loader begins to build the 
transfer vector by saving the name of the called 
subroutine. 



~l 

Name of Subroutine 
1 
1 


Zeros 



Subsequent LIBF statements produce additional 
records for the Transfer Vector, each containing a 
unique subroutine name. Calls to a subroutine pre- 
viously listed in the transfer vector do not produce 
a new record. Ultimately each causes a short, 
indexed BSI instruction pointing to the first word of 
the associated Transfer Vector entry. This in- 
struction, generated during loading, uses Index 
Register 3 and a computed displacement to refer to 
the proper Transfer Vector entry. 

Original Statement 



Lobal 

21 25 




Operation 

27 30 




F 

32 


T 
33 







35 40 


45 




III l 




LJ.Bf 










N t AM,E l . i i 






... II 1 1 




1 L -1 . 










_i_ .± i i i i i i i i ■ i i • 



Modified Statement 



Operation 



B t S , I t j 



i 



^» 



w 



« V , 5 , P , M , C , f , Af , £-,*, r , , , 



M-L. 



When this BSI instruction is encountered during ex- 
ecution of the main program, it causes a branch to 
the associated Transfer Vector entry and from 
there to the entry point of the subroutine. A BSI 
statement is generated for each LIBF statement 
encountered. 



NOTE: Index Register 3 is reserved for LIBF sub- 
routine calls. Therefore, if any instructions are to 
use Index Register 3, it should be restored prior 
to any LIBF subroutine call. 
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MONITOR ASSEMBLER STATEMENTS 



In addition to the basic assembler statements, the 
IBM 1130 Monitor Assembler is provided with the 
following capabilities. 

Disk Data Organization 

DSA - Define Sector Address 
FILE - Define Disk File (DM2 only) 

""*" ' 6 **^' 1 »'»«l»'««^«»« ff ^ 

Data Definition 

DMES - Define Message (DM2 only) 
DN - Define Name (DM2 onl^ 






Linking 
LINK 
EXIT 
DUMP 

i— — imiTmrrmi 

PDMP 



Load and Execute Another Program 
Return Control to Supervisor 
Dump and Terminate (DM2 only) 

»WIWlW'Wftl«IB«»WMl»W!Wi^i^ 

Dump and Continue (DM2 only) 



List Control 

HDNG - Print Heading on Each Page 

LIST - List Segments of Pr ograms (DM2 only) 

— - umi — » ■ "■ —■■i—— * ■—■»■» " ' m i ni """' » 

TETCt - ^SEart New Page (DM2 only) 



*mtmmrm0ti m*vi< i* * m "*"' 



"wwwwsim,*. 



DISK DATA ORGANIZATION STATEMENTS 



DSA - Define Sector Address 

The DSA statement allows the programmer to refer 
symbolically to a disk-stored data file or program 
stored in Disk Core Image format (DCI) without 
knowing the specific disk location of the data or 
program. The disk location of data files and pro- 
grams can vary on disk because of deletions, but the 
DSA statement allows easy reference through the 
use of the symbolic name of the data file or program. 
The format of the DSA statement is : 



L,A,B,B,L 



Operotlo 



43A 



Operandi & Rei 



\/iA,M £, i i l_j_ 



The label is defined as the current value of the Loca- 
tion Assignment Counter when the DSA statement is 
encountered. The symbol in the operand field must 
be the name of a data file or DCI program that is on 
disk both when the assembly is made and during 
execution. 

The following statements illustrate the use of 
the DSA statement to read one sector of data. For 
a description of the disk calling sequences, see the 
system subroutines library manual. 



Label 

21 25 


| 


Operation 

27 30 


f 


F 

32 


T 

33 


1 


Operandi & Re 

35 40 45 50 




S? 


• . . 


n 






:■$ 


















• i i 




1 

























L.1,8 


F 








ii 


DJfiXX . 
















D,C, 




&£ 






i$ 


/J, 0,0,0, , 
















o,c, 




i; 






w 


I.O.A,/?, , , 






i i i i i 










o,c, 




® 








B&RCR, , 
















*, , 






















1. CA.fi 






D,S, A 












O t A,r,A, , . 
















6,S,S 












3J.9, , , . 
















•, , 


























$:j 


• , , 






































k 


i i i i i i 














m 






H? 






w& 













_l I I L_l. 



The Assembler reserves three words in the object 
program for each DSA statement. These words are 
filled in by the Core Load Builder. For a data file 
they will contain: 

Word 1 — Length (in words) 

Word 2 — Sector Address, including the drive code 

Word 3 — Sector count of the file 

For a program they will contain: *° 

Word 1 — Length (in words) 

Word 2 — Sector Address, including the drive code 

Word 3 — Execution Address of the Program 

If the area corresponding to the DSA statement 
is used as the I/O area for a disk read operation, 
the execution address of the program must be saved 
prior to the disk call to bring in the program. (The 
contents of the third word are destroyed by the 
incoming data) . 
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The following statements illustrate the use of 
the DSA statement to supply the disk address of a 
one-sector program. 



Label 
21 25 




Operation 




f 

32 


T 

33 




Operands & Re 

35 40 45 50 


1 1 I 1 




•l . 1 




















1 1 1 I 




•. . 1 






































_1 1 1 1 




LA, . 










I,0,A,R,+,2 




























1 1 I I 




SJA 










B,RN,C,H,+ 


lX 


























R,E,A,D, 




L,I,B,F 










ai.sxj, 




























i i i i 




&A , 










AJ. 0.0,0, 
































D,C, , 










1,0, AR, , 




























i i i i 




D,C, , 










E&R.0.G, 




























C,A,L,L, 




L,I,B,F 










DJ,S,K,1, 




























i i i i 




D.C. . 










/.0.0,0,0, 




























i i i i 




D.C, , 










I,0,A,R, , 
































MAX, 










CiA.L.L, , 




























B,R,N,C,H 




B,S,C, 




L 






0, , , , , 




























i i i i 




•, , , 






































i i i i 




• iii 






































i i i i 




• i i i 






































i,o,a,r, 




D,S, A, 










P x R t G,R,M, 




























i i i i 




3,S, S, 


w 








3J.9, , , 
































»■ , , 










































*, , i 






































i i i i 




i i i 


-*r 








i i i i i 






—j 























The following statements can be added to the 
previously shown program call to call a second pro- 
gram and have it loaded to the same area as the 
first. 



Label 

21 ?5 




Operation 




F 

3? 


T 




Operands & Rer 

35 40 45 50 


l I i 






LA, 












A.P.R.2, , , 












S.T.O 












i,o.A,e, , , , 
























LA, 












A,D,R,2,+J, , 
























S,T,0 












I.0,A,B,+J. , 
























LA, 












AxD,R,Z,-h,Z, , 


















' ■ r 






S,T,0 












B,R,N,C,H,+,1, 


















1 1 






MAX 












R,E,AA, i ■ , 


















AA.RZ 






D,S t A 












P t G,RMZ, . , 
























I | 




































♦ ■ . 






























i i i 






















i 



















































The execution address of the second program can be 
different from the first, but the programs must be 
executable from the same locations. This requires 
a certain amount of planning before assembling the 
"overlay" programs. 



Programming Considerations 

The following considerations must be observed by 
the user who wishes to use the DSA statement to 
supply the disk address for programs. 



• The called programs must be in DCI format. 

• If the calling program is converted to DCI format, 
the data for the DSA statement is filled in during 
the core image conversion and will be fixed for all 
subsequent executions. Thus, if the referenced 
program or data files are subsequently moved, 
incorrect results will occur. Data files refer- 
enced by a Core Image program should be stored 
in the Fixed area. 

• Any loading functions, such as the setting of Index 
Register 3, will have to be supplied by the calling 
program. 




FILE - Define Disk Filf? (DM2) 



The FILE statement specifies to the Assembler the 
file identification, the number of file records in a 
file, and the size of each record in a disk data file 
that will be used with a particular mainline and its 
associated subprograms. The Assembler FILE 
statement allows the Assembler language user to 
defile files so that they are similar to FORTRAN 
defined files. 

As a core load is constructed by the Core Load 
Builder, the defined files are equated to data files 
already assigned in the User/Fixed Area or to files 
in Working Storage. 

The FILE statement must not appear in a sub- 
program; it is permitted only in a relocatable main- 
line program. Therefore, all subprograms used 
by the mainline must use the defined files of the 
mainline. The format of the FILE statement is as 
follows: 



Label 

?1 25 




Operation 

27 30 




F 

32 


T 

33 




Operandi & Rer 

35 40 45 50 


£, , , , 




fJAE 










GtjM^fl.jtUj^v, , i , , 


1 1 1 1 




i i i 





























where 

1 is any valid label (optional), 

a is the file identification number, a decimal 
integer in the range 1-32767, 

m is a decimal integer that defines the number 
of records in the file, 

n is a decimal integer in the range 1-320 that de- 
fines the length (in words) of the longest record 
in the file, 
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U is a required constant, specifying that the file 
must be read/written with no data conversion, 

v is the associated variable, the label of a core 
location (variable) defined elsewhere in the pro- 
gram. 



FILE statements must precede all other state- 
ments except HDNG, EPR, SPR, EJCT, SPAC, and 
LIST in the source program. The label, if used, is 
assigned the location of the first word of the seven 
words generated (see list below). The Format and 
Tag fields are not used and should be left blank. 

Each FILE statement causes the Location Assign- 
ment Counter to be incremented by seven. The data 
stored in these seven words, which constitute a 
DEFINE FILE Table entry in the object program is 
as follows: 



Word Contents 

1 a, the file identification number 

2 m, the number of records per file 

3 n, the record length (in words) 

4 The address of the associated variable, v. 

5 Zero. This word is filled by the Core 

Load Builder with the sector address of the 
data file. This address is relative to the 
address of Working Storage (with bit zero 
set to one) for Working Storage files and is 
absolute, including the drive code, for User/ 
Fixed area files. 

6 r, the number of records per sector. The 

number, computed by the Assembler, is 
the quotient of 



320 



(remainder ignored) 
b, the number of disk blocks per file. 
This number, computed by the Assembler, 
is the quotient of 

16(m) 
r 



DATA DEFINITION STATEMENTS 



DMES - Define Message (DM2) 



V //^ 






The DMES statement is used to store a message with- 
in a program in a form that is acceptable to the 
printer output subroutines. The format of the DMES 
statement follows: 



Sgj Ope ratio 



\ DM£3 



f>mtrL 



Operandi & Rer 



_l I I I I J I 1_ 



J 1 1 I I I l_ 



where 

1 is any valid label (optional), 

p is the printer type code, 

m is any string of valid message and control 
characters. 

If a label is present, it is assigned to the location 
of the first word generated. The Tag field (column 
33) is used to specify the printer type code: 

Tag Printer 

^b or Console Pri nte r 

1 "" 1403~Pr inter ' 

2 1132 Printer 

If the Tag field (printer type code) contains a char- 
acter other than blank, zero, one, or two, an error 
results and the message is stored two EBCDIC char- 
acters per word. 

The Operand field contains the control and mess - 
age characters. Remarks are permitted only after 
an 'E or 'b control character. 

The output generated by one DMES statement can- 
not exceed 60 words (120 characters). If an odd 
number of characters is generated, the last word is 
filled in with a blank, except when the statement 
ends with 'b. In this case, the first character of the 
next DMES statement is used to fill out the word. 

Control characters are used to specify certain 
printer operations and to define message parameters. 
Each control character is actually two characters, 
the first of which is always an apostrophe. The apos- 
trophe (5-8 punch in IBM Card Code) is a control 
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delimiter and therefore is not included in the char- 
acter count. The control characters and their func- 
tions or meanings are as follows: 



Assembler input: 



Control 




Character 


Function or Meaning 


*X 


Blank (or space) 


*T 


Tabulate 


'D 


Backspace 


'B 


Print black 


. 'A 


Print red 


'S 


Space (or blank) 


'R 


Carriage return 


'L 


Line feed 


'F 


Repeat following character 


'E 


End of message 


•b 


(b=blank) continues text with next DMES 




statement 



Label 


l 


Operation 


K 


F 


T 


^ 


Operands & ft.-marks 










DME,S 










',R,S,A,M,P,L,E, ,P,R,0,G,R,AM,' ,' ,S,' 




, , 






DMES 








B 


,o,u,t,p,u,t, j i i _j._L._i i _i t t ! 








M 


DM£,S 








i 


',2,/?, ',9,9,1,' ,9,S,2,' ,9,S,3,',9,S,4,' ,£> , , . 










DMES 


'$& 








' ,R,l,Z,3A£~6,7,S,9 t <p,l,2,3,4,5,<b,7&9,' , , . 










D,M S E,S 










04 2,3,4,5,6,7,8,9,0,1, Z,3,4,5,tp,7A9,0, ',£_ , 








:|& 


DMES 


i 








',2,1?, ', 7^',7,F M ' L 4 L 0J[ Cx,)^-, \ , L , 










DMES 








' ,7, X,' ,8, F,-,',5,D,F,',' ,(,*,),-, — ,',£, , , , 




______J 




« 




p 




^ 




-.1 J 1 _J 1 I .___._. L.J 1 1__ L 1 __L____| 1 1„_1_1_J 



Printed output: 

SAMPLE PROGRAM'S OUTPUT 

12 3 4 

12 3456789012 3456789012 34 5678901234567890 



F(X) 



F' (X) 



All the above characters can be used when the printer 
is the Console Printer. Only 'E, 'F, 'S, 'X and r b 
are valid control characters when the 1132 or 1403 
Printer is specified; any other control characters 
are considered as errors. 

The characters T X and 'S are interchangeable. A 
blank character is generated for either 'X or 'S if the 
1132 or 1403 Printer is specified; a space is gener- 
ated for either 'X or 'S if the Console Printer is 
specified. 

The character 'F (repeat following character) 
refers on ly to message characters. The control 
characters themselves, except 'A, T B, 'E, and ! b, 
can be repeated up to 99 times by inserting a number 
(1-99) between the apostrophe and unique control 
definition character. For example, T 32S results in 
32 space characters being inserted in the generated 
message. 

The character T E is used to designate the end of 
the message line. The character 'b is used to desig- 
nate that the message is continued on the following 
DMES statement. If neither 'E nor T b is included, 'E 
is assumed to follow column 71. DMES statements 
that end with 'b must be followed by another DMES 
statement. 

Text apostrophes are generated by writing two 
successive apostrophes. 

The message characters can be any valid charac- 
ter for the printer being used. Invalid characters 
are replaced with blanks. 

The following example illustrates the DMES 
statement. 



Note that the device code specified in the preceding 
example is blank in order to generate a message for 
the Console Printer. 



DN - Define Name \/ 2- 0"Wa."v-J 

The Define Name statement is used to convert a 
name specified in the Operand field of the state- 
ment to a name in Name Code in the object pro- 
gram. The format of this statement is shown 
below : 



TZ 



1 ' ■ m 



Operation •: 



DM , 



1 



Operands & Rer 



|* 



i — I L— I 1 1 — 1 1 L_.L_J.__J L__l I l_ I _ 



where 

1 is any valid label (optional), 
n is any valid label or name. 

Name Code is truncated packed EBCDIC. The two 
high order bits of each character in the name are 
removed and the five characters are packed into the 
right thirty bits of two words. 



oo 



A i 



xx |xx xxxx|xxxx xx|xx xxjxxixxxx XX|XX xxxx | 
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If a label is used, the address assigned to it is the 
location of the first word of the two words generated 
and is equal to the current value of the Location 
Assignment Counter. Columns 32 and 33 must be 
blank. The operand can have up to five characters 
that comply with the rules for writing symbols. The 
name to be converted must be left- justified in the 
Operand field. If remarks are used, one blank must 
be left between the operand and the remarks. The 
Location Assignment Counter is incremented by two 
for this statement. 



LINKING STATEMENTS 



LINK — Load Link Program 

In the assembler language, the LINK statement is 
used to cause another core load to be loaded and 
executed. Only COMMON of the current core load 
is saved. The program loaded and executed must 
be specified by name. The format of the LINK 
statement is: 

1. A symbol or blanks in the label field 

2. The mnemonic, LINK, in columns 27-30 

3. A valid program name in the operand field 

The label of the LINK pseudo-operation is de- 
fined as the current value of the Location Assignment 
Counter when the LINK statement is encountered; 
this value is the address of the first word generated 
by the LINK statement. 

The operand field contains a valid program name 
(one to five alphameric characters), left-justified in 
the field. The name must be present in LET/FLET 
at execution time. The LINK statement causes four 
words to be generated in the object program. The 
first two words contain a long BSI instruction, which 
branches to a specified location within the Skeleton 
Supervisor. The next two words contain the program 
name, left-justified in bits 2-32, with blanks inserted 
in unused rightmost positions (bits and 1 are always 
zero). The Core Image Loader uses the core load 
name and begins the process required to load the new 
core load. 



EXI T — Return to Supervisor 

In the assembler language, the EXIT statement is 
used to return control to the Supervisor. The format 
of the EXIT statement is: 



1. A symbol or blanks in the label field 

2. The mnemonic, EXIT, in columns 27-30 

The label of the EXIT statement is defined as 
the current value of the Location Assignment Counter 
when the EXIT statement is encountered; this value 
is the address of the instruction generated by an 
EXIT statement. The operand field is ignored and 
can therefore be used for remarks. 

The EXIT statement causes a short branch in- 
struction to be generated in the object program. 
The instruction branches to a fixed location in the 
Skeleton Supervisor. During execution, the branch 
is executed and control is returned to the Supervisor. 
The EXIT statement should be the last logical state- 
ment in a program. 



\/ ci- (jrwU 



DUMP — Dump and Terminate Execution 



3 



The DUMP statement provides an entry to the System 
DUMP program, which prints the contents of core 
storage on the principal print device in hexadecimal 
format. 

The DUMP statement allows for flexible specifica- 
tion of the upper and lower limits to be dumped with- 
out altering core storage. After core has been 
dumped between the limits specified, the System 
Dump returns control to the calling program, at 
which point a CALL EXIT is executed. The DUMP 
statement is written as follows: 



Operation \ 



DjJMEM 



Operandi & Ren 



!«.,.*■ „/i 



.j i i i i_ 



_j i i i u 



where 

I is any valid label (optional) , 

a is any valid expression specifying the lowest- 
addressed core location to be dumped, 

b is any valid expression specifying the highest- 
addressed core location to be dumped, 

f is the dump format code (either blank or zero). 
The dump is always in hexadecimal format. 

The label, if used, is assigned the location of the 
first of the six words generated (see list below). 
The Tag and Format fields must be left blank. 
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A DUMP statement causes the Location Assign- 
ment Counter to be incremented by six. The data 
stored in these six words is as follows: 



Word 



w 

3 
4 
5 
6 



Contents 

A long (two-word) BSI to the DUMP entry 

point in the Skeleton Supervisor 
The starting address of the core dump 
The ending location of the core dump 
The format indicator (always zero) 
A short branch to the EXIT entry point 
in the Skeleton Supervisor 



If no address is specified for word 3, the dump 
starts in location zero. If no address is specified 
for word 4, the dump continues to the end of core. 

A DUMP statement can be used at any point in a 
program; however, the user is reminded that DUMP 
causes a terminal DUMP to be printed. At the com- 
pletion of the dump printout, the branch to EXIT is 
executed, thus transferring control to the Skeleton 
Supervisor for processing of the next job or subjob. 

The format of the DUMP program output is as 
follows: 

AAAA xxxx xxxx xxxx u xxxx xxxx xxxx 

The contents (xxxx) of 16 core storage locations are 
printed per line. At the left is the address (AAAA) 
of the first location printed on that line. 



PDMP — Dump and Continue Execution 



The PDMP statement provides the ability to dump 
core storage between specified limits and to continue 
execution. The core dump is printed on the principal 
print device without altering core. The PDMP state- 
ment is specified in the same way as DUMP, except 
that PDMP appears in columns 27-30 instead of 
DUMP. 

The PDMP statement is translated by the Assem- 
bler into a long BSI to the DUMP entry point in the 
Skeleton Supervisor. The parameters (operands) are 
converted as described in the DUMP statement (see 
above) except that the exit to the Supervisor is not 
generated for PDMP. 

Upon completion of the printout of the core dump, 
control is returned to the next instruction following 
the PDMP statement to continue execution. 



LIST CONTROL STATEMENTS 

The list control statements — HDNG, LIST, SPAC, 
and EJCT — provide the user with the means to 
control and identify the assembler output listing. 



HDNG — Heading 

The HDNG statement is used to specify a one line 
page heading for a printed listing. The heading 
line consists of the data in the Operand-Remarks 
field. 

The format of the HDNG statement is as follows. 



Label 

21 25 


l 


Operation 

27 30 




F 

32 


T 

33 




Operandi & Rei 

35 40 45 50 


1 1 I 1 




H.DMG 










P.A,G,£, .H.E.A.D./MG 



































Multiple HDNG statements may be used thus 
allowing different sections of a listing .to have 
different page headings. 

When the 1132 or 1403 is the principal printer, 
the HDNG statement causes the listing to be ejected 
to a new page and the heading is printed. The same 
heading is repeated at the top of each succeeding 
page until a new HDNG statement is encountered. 

When the Console Printer is the principal printer, 
the heading line is preceded by five line feeds and 
followed by a single line feed, and otherwise functions 
as a comments statement. 



LIST — List Segments of Program 



V2- ^S 



The LIST statement allows the user to list certain 
segments of a program on the principal printer and 
avoid listing other segments. The three variations 
of the LIST statement are shown below: 



OperatK 



L.I.S.T J 



L.I.ST 



L.I.ST 



Operandi & Ren 



l-»- 



QxiL 



lQ i F ± R_ 



The Label, Tag, and Format fields are not used 
with the LIST statement and should be left blank. The 
Operand field may be left blank or may contain the 
operand ON or OFF. 
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The LIST statement does not cause the Location 
Assignment Counter to be incremented. 

If a LIST statement with the operand ON is en- 
countered, the following statements, up to the next 
LIST statement, are listed by the Assembler. 

If a LIST statement with no operand is encountered, 
the Assembler assumes an operand depending on the 
use of the LIST control record. If the LIST control 
record preceded the assembly, the ON operand is 
assumed and the Assembler acts accordingly. If 
the LIST control record did not precede the assembly, 
the OFF operand is assumed and the Assembler acts 
accordingly. 

SPAC — Spa ce Listing 1 / / /fv^U^ 

The SPAC statement is used to insert one or more 
blank lines in the listing immediately following the 
SPAC statement. The format of the SPAC state- 
ment is as follows: 



Operation :■ 



S, P , Afi j 



Operandi & Rei 



where e is any valid positive expression. 

The Label, Format, and Tag fields are not used 
and should be left blank. 

The number of blank lines inserted in the listing 
is determined by the operand in the statement. The 



operand can be any valid expression. The operand 
(expression) value must be positive; otherwise, the 
Assembler ignores the statement. 

When the number of blank lines specified exceeds 
the number of lines left on the page, the page is 
spaced to the bottom, a restore occurs, a new 
heading is printed, and spacing is resumed until the 
number of blank lines specified has been exhausted. 

The SPAC statement does not cause the Location 
Assignment Counter to be incremented. 



EJCT — Start New Page 



\IZ 



(J'^Ai^jrx 



The EJCT statement causes the next line of the list- 
ing to appear at the top of a new page following the 
page heading. The format of the EJCT statement is 
as follows: 



Operatic 



EJ.CJ 



Operands & Re 



_1 I I l l_ 



_L I I I I I L 



_l l I 1 I I I I I t I I J I 1 I J 1 L. 



The Label, Tag, Format, and Operand fields are not 
used and should be left blank. 

A page overflow occurs immediately following the 
EJCT statement. EJCT statements may be used in 
succession to obtain blank pages (except for the 
headings printed). 

The EJCT statement does not cause the Location 
Assignment Counter to be incremented. 
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APPENDIX A. CHARACTER CODE SUMMARY 



Hexadecimal Notation 

In hexadecimal notation, each digit represents a 
four -bit binary value. This means that a 16 -bit 
word in the Processor-Controller can be expressed 
as four hexadecimal digits. The binary — hexa- 
decimal — decimal correspondence is defined as 
follows : 



Binary 

0000 
0001 
0010 
0011 
0100 
0101 
0110 
0111 
1000 
1001 
1010 
1011 
1100 
1101 
1110 

1111 



Hexadecimal 


Decimal 








1 


1 


2 


2 


3 


3 


4 


4 


5 


5 


6 


6 


7 


7 


8 


8 


9 


9 


A 


10 


B 


11 


C 


12 


D 


13 


E 


14 


F 


15 



Extended Binary Coded Decimal Interchange Code 
(EBCDIC) 

In the EBCDIC code, each character is represented 
by a unique configuration of eight binary bits. In 



the table that follows, each EBCDIC character is 
expressed as two hexadecimal digits. 

IBM Card Code 

In the IBM Card Code, each character represents a 
12 -bit card-column image. In the table that follows, 
each card code character is expressed as four hexa- 
decimal digits and as the card-column image. 

Paper Tape Transmission Code, 8 Channel (PTTC/8) 

In the PTTC/8 code, each character is represented 
by a unique configuration of a case shift, plus an 
eight-bit code. The case shift can be common to 
more than one character and need be inserted only 
when a case shift change is necessary. In the table 
that follows, each character is expressed as two 
hexadecimal digits, followed by the case shift in 
parentheses. 

1132 Printer EBCDIC Subset Hex Code 

In the 1132 Printer EBCDIC subset hex code, each 
character is represented by a unique configuration of 
eight bits. In the table that follows, each 1132 
Printer character is expressed as two hexadecimal 
digits. 

Console Printer Hex Code 

In the Console Printer hexadecimal code each charac- 
ter is represented as two hexadecimal digits. 

1403 Printer Hex Code 

In the 1403 Printer hexadecimal code each character 
is represented as two hexadecimal digits. 
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EBCDIC 


IBM Card Code 






1132 


PTTC/8 
Hex 

U -Upper Case 


Console 


1403 


Ref 
No. 


Binary 


Hex 




Rows 




Hex 


Graph 


cs and Control 
Names 


Printer 
EBCDIC 


Printer 
Hex 


Printer 




0123 


4567 




12 11 9 8 


7-1 








Subset Hex 


L-Lower Case 


Notes 


Hex 





0000 


0000 


00 


12 


9 8 


1 


B030 


NUL 












1 






0001 


01 


12 


9 


1 


9010 














2 






0010 


02 


12 


9 


2 


8810 














3 






0011 


03 


12 


9 


3 


8410 














4 






0100 


04 


12 


9 


4 


8210 


PF 


Punch Off 










5* 






0101 


05 


12 


9 


5 


8110 


HT 


Horiz.Tab 




6D(U/L) 


41 © 




6* 






0110 


06 


12 


9 


6 


8090 


LC 


Lower Case 




6E (U/L) 






7* 






0111 


07 


12 


9 


7 


8050 


DEL 


Delete 




7F (U/L) 






3 






1000 


08 


12 


9 8 




8030 














9 






1001 


09 


12 


9 8 


1 


9030 














10 
11 






1010 
1011 


OA 
OB 


12 
12 


9 8 
9 8 


2 

3 


8830 
8430 














12 






1100 


oc 


12 


9 '8 


4 


8230 














13 






1101 


OD 


12 


9 8 


5 


8130 














14 






1110 


OE 


12 


9 8 


6 


80B0 














15 


" 


mi 


OF 


12 


9 8 


7 


8070 














16 


0001 


0000 


10 


12 1 


1 9 8 


1 


D030 














17 






0001- 


11 




1 9 


1 


5010 














18 






0010 


12 




1 9 


2 


4810 














19 






00 il 


13 




1 9 


3 


4410 










*-■>*. 




20* 






0100 


14 




1 9 


4 


4210 


RES 


Restore 




4C (U/L) 


05 © 




21* 






0101 


15 




1 9 


5 


4110 


NL 


New Line 




DD(U/L) 
5E (U/L) 


81 (3) 




22* 






0110 


16 




1 9 


6 


4090 


BS 


Backspace 




11 




23 






0111 


17 




1 9 


7 


4050 


IDL 


Idle 










24 






1000 


18 




1 9 8 




4030 














25 






1001 


19 




1 9 8 


1 


5030 














26 






1010 


1A 




1 9 8 


2 


4830 














27 






1011 


IB 




1 9 8 


3 


4430 














28 






1100 


1C 




1 9 8 


4 


4230 














29 






1101 


ID 




1 9 8 


5 


4130 














30 






1110 


IE 




1 9 8 


6 


40B0 














31 


' 


1 


mi 


IF 




1 9 8 


7 


4070 














32 


0010 


0000 


20 


1 


10 9 8 


1 


7030 














33 






0001 


21 




9 


1 


3010 














34 






0010 


22 




9 


2 


2810 














35 






0011 


23 




9 


3 


2410 














36 






0100 


24 




9 


4 


2210 


BYP 


Bypass 










37* 






0101 


25 




9 


5 


2110 


LF 


Line Feed 




3 D (U/L) 


03 




38* 






0110 


26 




9 


6 


2090 


EOB 


End of Block 




3E(U/L) 






39 






0111 


27 




9 


7 


2050 


PRE 


Prefix 










40 






1000 


28 




9 8 




2030 














41 






1001 


29 




9 8 


1 


3030 














42 






1010 


2A 




9 8 


2 


2830 














43 






1011 


2B 




9 8 


3 


2430 














44 






1100 


2C 




9 8 


4 


2230 














45 






1101 


2D 




9 8 


5 


2130 














46 






1110 


2E 




9 8 


6 


20B0 














47 


< 


1 


mi 


2F 




9 8 


7 


2070 














48 


0011 


0000 


30 


12 1 


10 9 8 


1 


F030 














49 






0001 


31 




9 


1 


1010 














50 






0010 


32 




9 


2 


0810 














51 






0011 


33 




9 


3 


0410 














52 






0100 


34 




9 


4 


0210 


PN 


Punch On 










53* 






0101 


35 




9 


5 


0110 


RS 


Reader Stop 




0D(U/L) 


09 © 




54* 






0110 


36 




9 


6 


0090 


UC 


Upper Case 




0E(U/L) 






55 






0111 


37 




9 


7 


0050 


EOT 


End of Trans. 










56 






1000 


38 




9 8 




0030 














57 






1001 


39 




9 8 


1 


1030 














58 






1010 


3A 




9 8 


2 


0830 














59 






1011 


3B 




9 8 


3 


0430 














60 






1100 


3C 




9 8 


4 


0230 














61 






1101 


3D 




9 8 


5 


0130 














62 






1110 


3E 




9 8 


6 


00B0 














63 


1 


' 


nn 


3F 




9 8 


7 


0070 















NOTES: Typewriter Output 
© Tabulate 
(2) Shift to black 



Carrier Return * Recognized by all Conversion subroutines 

Shift to red Codes that are not asterisked are recognized only by the SPEED subroutine 
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Ref 
No. 


EBCDIC 


IBM Card Code 


Graphics and Control 
Names 


1132 
Printer 


PTTC/8 
Hex 


Console 
Printer 


1403 
Printer 




Binary 


Hex 






Rows 




Hex 




0123 4567 




12 


11 


9 8 


7-1 




EBCDIC 
Subset Hex 


U-Upper Case 
L-Lower Case 


Hex 


Hex 




64* 0100 0000 


40 




no punches 




0000 


blank 


40 


10 (U/L) 


21 


7F 




65 


0001 


41 


12 




9 


1 


B010 












66 


0010 


42 


12 




.9 


2 


A810 














67 


0011 


43 


12 




9 


3 


A410 














68 


0100 


44 


12 




9 


4 


A210 














69 


0101 


45 


12 




9 


5 


A110 














70 


0110 


46 


12 




9 


6 


A090 














71 


0111 


47 


12 




9 


7 


A050 














72 


1000 


48 


12 




9 8 




A030 














73 


1001 


49 


12 




8 


1 


9020 














74* 


1010 


4A 


12 




8 


2 


8820 


* 




20 (U) 
6B L) 
02 (U) 
19 U) 
70 U) 
3B(U) 


02 






75* 


1011 


4B 


12 




8 


3 


8420 


(period) 


4B 


00 


6E 




76* 


1100 


4C 


12 




8 


4 


8220 


< 




DE 






77* 


1101 


4D 


12 




8 


5 


8120 


( 


4D 


FE 


57 




78* 


1110 


4E 


12 




8 


6 


80A0 


+ 


4E 


DA 


6D 




79* V 1111 


4F 


12 




8 


7 


8060 


1 (logical OR) 




C6 






80* 0101 0000 


50 


12 








8000 


& 


50 


70 (L) 


44 


15 




81 


0001 


51 


12 


11 


9 


1 


D010 














82 


0010 


52 


12 


11 


9 


2 


C810 














83 


0011 


53 


12 


11 


9 


3 


C410 














84 


0100 


54 


12 


11 


9 


4 


C210 














85 


0101 


55 


12 


11 


9 


5 


C110 














86 


0110 


56 


12 


11 


9 


6 


C090 














87 


0111 


57 


12 


11 


9 


7 


C050 














88 


1000 


58 


12 


11 


9 8 




C030 














89 


1001 


59 




11 


8 


1 


5020 














90* 


1010 


5A 




11 


8 


2 


4820 


! 




5B(U) 


42 






91* 


1011 


5B 




11 


8 


3 


4420 


$ 


5B 


5B(L) 


40 


62 




92* 


1100 


5C 




11 


8 


4 


4220 


* 


5C 


08(U) 


D6 


23 




93* 


1101 


5D 




11 


8 


5 


4120 


) 


5D 


1A(U) 


F6 


2F 




94* 

95* 1 


1110 


5E 




11 


8 


6 


40A0 






13 (U) 


D2 






' mi 


5F 




11 


8 


7 


4060 


A (logical NOT) 




6B(U) 


F2 






96* 0110 0000 


60 




11 






4000 


- (dash) 


60 


40 (L) 


84 


61 




97* 


0001 


61 









1 


3000 


/ 


61 


31 (L) 


BC 


4C 




98 


0010 


62 




11 


9 


2 


6810 














99 


0011 


63 




11 


9 


3 


6410 














100 


0100 


64 




11 


9 


4 


6210 














101 


0101 


65 




11 


9 


5 


6110 














102 


0110 


66 




11 


9 


6 


6090 














103 


0111 


67 




11 


9 


7 


6050 














104 


1000 


68 




11 


9 8 




6030 














105 


1001 


69 






8 


1 


3020 














106 


1010 


6A 


12 


11 






COOO 














107* 


1011 


6B 






8 


3 


2420 


, (comma) 


6B 


3B(L) 


80 


16 




108* 


1100 


6C 






8 


4 


2220 


% 




15 (U) 


06 






109* 


1101 


6D 






8 


5 


2120 


(underscore) 




40 (U) 
07 (U) 
31 (U) 


BE 






110* 


1110 


6E 






8 


6 


20A0 


> 




46 






111* t 1111 


6F 






8 


7 


2060 


? 




86 






112 0111 0000 


70 


12 


11 







E000 














113 


0001 


71 


12 


11 


9 


1 


F010 














114 


0010 


72 


12 


11 


9 


2 


E810 














115 


0011 


73 


12 


11 


9 


3 


E410 














116 


0100 


74 


12 


11 


9 


4 


E210 














117 


0101 


75 


12 


11 


9 


5 


El 10 














118 


0110 


76 


12 


11 


9 


6 


E090 














119 


0111 


77 


12 


11 


9 


7 


E050 














120 


1000 


78 


12 


11 


9 8 




E030 














121 


1001 


79 






8 


1 


1020 














122* 


1010 


7A 






8 


2 


0820 






04 (U) 
0B (L) 


82 






123* 


1011 


7B 






8 


3 


0420 


# 




CO 






124* 


1100 


7C 






8 


4 


0220 


® 




20 (L) 


04 






125* 


1101 


7D 






8 


5 


0120 


' (apostrophe) 


7D 


16 (U) 


E6 


0B 




126* 


1110 


7E 






8 


6 


00A0 


= 


7E 


01 (U) 


C2 


4A 




127* f 1111 


7F 






8 


7 


0060 






0B(U) 


E2 
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EBCDIC 


IBM Card Code 


Graphics and Control 
Names 


1132 
Printer 
EBCDIC 


PTTC/8 


Console 


1403 


Ref 
No. 


Binary 


Hex 




Rows 


Hex 


Hex 

U -Upper Case 


Printer 
Hex 


Printer 
Hex 




0123 4567 




12 11 9 8 7-1 






Subset Hex 


L-Lower Case 




128 


1000 0000 


80 


12 


8 1 


B020 












129 




0001 


81 


12 


1 


BOOO 


a 










130 




0010 


82 


12 


2 


A800 


b 










131 




0011 


83 


12 


3 


A400 


c 










132 




0100 


84 


12 


4 


A200 


d 










133 




0101 


85 


12 


5 


A100 


e 










134 




0110 


86 


12 


6 


A080 


f 










135 




0111 


87 


12 


7 


A040 


g 










136 




1000 


88 


12 


8 


A020 


h 










137 




1001 


89 


12 


9 


A010 


i 










138 




1010 


8A 


12 


8 2 


A820 












139 




1011 


8B 


12 


8 3 


A420 












140 




1100 


8C 


12 


8 4 


A220 








| 


141 




1101 


8D 


12 


8 5 


A120 












142 




1110 


8E 


12 


8 6 


AOAO 












143 


i 


1111 


8F 


12 


8 7 


A060 












144 


1001 0000 


90 


12 1 


1 8 1 


D020 












145 




0001 


91 


12 1 


1 1 


DOOO 


i 










146 




0010 


92 


12 1 


1 2 


C800 


k 










147 




0011 


93 


12 1 


1 3 


C400 


1 










148 




0100 


94 


12 


1 4 


C200 


m 










149 




0101 


95 


12 


1 5 


C100 


n 










150 




0110 


96 


12 


1 6 


C080 













151 




0111 


97 


12 


1 7 


C040 


P 










152 




1000 


98 


12 


1 8 


C020 


q 










153 




1001 


99 


12 


1 9 


C010 


r 










154 




1010 


9A 


12 


1 8 2 


C820 












155 




1011 


9B 


12 


1 8 3 


C420 












156 




1100 


9C 


12 


1 8 4 


C220 












157 




1101 


9D 


12 


1 8 5 


C120 












158 




1110 


9E 


12 


1 8 6 


COAO 












159 


' 


r mi 


9F 


12 


1 8 7 


C060 












160 


1010 0000 


AO 




10 8 1 


7020 












161 




0001 


A1 




1 1 


7000 












162 




0010 


A2 




1 2 


6800 


s 










163 




0011 


A3 




1 3 


6400 


t 










164 




0100 


A4 




1 4 


6200 


u 










165 




0101 


A5 




1 5 


6100 


V 










166 




0110 


A6 




1 6 


6080 


w 










167 




0111 


A7 




1 7 


6040 


X 








168 




1000 


A8 




1 8 


6020 


y 








169 




1001 


A9 




1 9 


6010 


z 








170 




1010 


AA 




10 8 2 


6820 












171 




1011 


AB 




10 8 3 


6420 












172 




1100 


AC 




10 8 4 


6220 












173 




1101 


AD 




10 8 5 


6120 












174 




1110 


AE 




10 8 6 


60A0 












175 


J mi 


AF 




11 8 7 


6060 












176 


1011 0000 


BO 


12 


11 8 1 


F020 












177 




0001 


Bl 


12 


11 1 


FOOO 












178 




0010 


B2 


12 


11 2 


E800 












179 




0011 


B3 


12 


11 3 


E400 












180 




0100 


B4 


12 


110 4 


E200 












181 




0101 


B5 


12 


11 5 


E100 












182 




0110 


B6 


12 


11 6 


E080 












183 




0111 


B7 


12 


110 7 


E040 












184 




1000 


B8 


12 


no 8 


E020 












185 




1001 


B9 


12 


11 9 


E010 












186 




1010 


BA 


12 


11 8 2 


E820 












187 




1011 


BB 


12 


11 8 3 


E420 












188 




1100 


BC 


12 


11 8 4 


E220 












189 




1101 


BD 


12 


11 8 5 


E120 












190 




1110 


BE 


12 


11 8 6 


EOAO 












191 




1 mi 


BF 


12 


11 8 7 


E060 










J _ 
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Ref 

No. 


EBCDIC 


IBM Card Code 


Graphics and Control 


1132 
Printer 


PTTC/8 
Hex 


Console 
Printer 


1403 
Printer 


Binary 


Hex 




Rows 




Hex 














Names 


EBCDIC 


U-Upper Case 








0123 4567 




12 


10 9 8 


7-1 






Subset Hex 


L-Lower Case 


Hex 


Hex 


192 1100 0000 


CO 


12 







A000 


(+ zero) 










193* 


0001 


CI 


12 




1 


9000 


A 


CI 


61 (U) 


3C or 3E 


64 


194* 


0010 


C2 


12 




2 


8800 


B 


C2 


62 (U) 


18 or 1A 


25 


195* 


0011 


C3 


12 




3 


8400 


C 


C3 


73 (U) 


1C or IE 


26 


196* 


0100 


C4 


12 




4 


8200 


D 


C4 


64 (U) 


30 or 32 


67 


197* 


0101 


C5 


12 




5 


8100 


E 


C5 


75 (U) 


34 or 36 


68 


198* 


0110 


C6 


12 




6 


8080 


F 


C6 


76 (U) 


10 or 12 


29 


199* 


0111 


C7 


12 




7 


8040 


G 


C7 


67 (U) 


14 or 16 


2A 


200* 


1000 


C8 


12 


8 




8020 


H 


C8 


68 (U) 


24 or 26 


6B 


201* 


1001 


C9 


12 


9 




8010 


1 


C9 


79 (U) 


20 or 22 


2C 


202 


1010 


CA 


12 


9 8 


2 


A830 












203 


1011 


CB 


12 


9 8 


3 


A430 












204 


1100 


cc 


12 


9 8 


4 


A230 












205 


1101 


CD 


12 


9 8 


5 


A130 












206 


1110 


CE 


12 


9 8 


6 


AOBO 












207 


> mi 


CF 


12 


9 8 


7 


A070 












208 1101 0000 


DO 




1 




6000 


(- zero) 










209* 


0001 


Dl 






1 


5000 


J 


Dl 


51 (U) 


7C or 7 E 


58 


210* 


0010 


D2 






2 


4800 


K 


D2 


52 (U) 


58 or 5A 


19 


211* 


0011 


D3 






3 


4400 


L 


D3 


43 (U) 


5C or 5E 


1A 


212* 


0100 


D4 






4 


4200 


M 


D4 


54 (U) 


70 or 72 


5B 


213* 


0101 


D5 






5 


4100 


N 


D5 


45 (U) 


74 or 76 


1C 


214* 


0110 


D6 






6 


4080 


O 


D6 


46 (U) 


50 or 52 


5D 


215* 


0111 


D7 






7 


4040 


P 


D7 


57 (U) 


54 or 56 


5E 


216* 


1000 


D8 




1 8 




4020 


Q 


D8 


58 (U) 


64 or 66 


IF 


217* 


1001 


D9 




1 9 




4010 


R 


D9 


49 (U) 


60 or 62 


20 


218 


1010 


DA 


12 1 


1 9 8 


2 


C830 












219 


1011 


DB 


12 1 


1 9 8 


3 


C430 












220 


1100 


DC 


12 1 


1 9 8 


4 


C230 












221 


1101 


DD 


12 1 


1 9 8 


5 


C130 












222 


1110 


DE 


12 1 


1 9 8 


6 


COBO 












223 


\ 


1 mi 


DF 


12 1 


1 9 8 


7 


C070 












224 


11 


10 0000 


EO 




8 


2 


2820 












225 


0001 


El 


1 


1 9 


1 


7010 












226* 


0010 


E2 







2 


2800 


S 


E2 


32 (U) 


98 or 9A 


0D 


227* 


0011 


E3 







3 


2400 


T 


E3 


23 (U) 


9C or 9E 


0E 


228* 


0100 


E4 







4 


2200 


U 


E4 


34 (U) 


B0 or B2 


4F 


229* 


0101 


E5 







5 


2100 


V 


E5 


25 (U) 


B4 or B6 


10 


230* 


0110 


E6 







6 


2080 


W 


E6 


26 (U) 


90 or 92 


51 


231* 


0111 


E7 







7 


2040 


X 


E7 


37 (U) 


94 or 96 


52 


232* 


1000 


E8 




8 




2020 


Y 


E8 


38 (U) 


A4 or A6 


13 


233* 


1001 


E9 




9 




2010 


Z 


E9 


29 (U) 


A0 or A2 


54 


234 


1010 


EA 




10 9 8 


2 


6830 












235 


1011 


EB 




10 9 8 


3 


6430 












236 


1100 


EC 




10 9 8 


4 


6230 












237 


1101 


ED 




10 9 8 


5 


6130 












238 


1110 


EE 




10 9 8 


6 


60B0 












239 ' 


I nn 


EF 




10 9 8 


7 


6070 












240* 1111 0000 


FO 









2000 





FO 


1A(L) 


C4 


49 


241* 


0001 


Fl 






1 


1000 


1 


Fl 


01 (L) 


FC 


40 


242* 


0010 


F2 






2 


0800 


2 


F2 


02 (L) 


D8 


01 


243* 


0011 


F3 






3 


0400 


3 


F3 


13 (L) 


DC 


02 


244* 


0100 


F4 






4 


0200 


4 


F4 


04 (L) 


F0 


43 


245* 


0101 


F5 






5 


0100 


5 


F5 


15 (L) 


F4 


04 


246* 


0110 


F6 






6 


0080 


6 


F6 


16 (L) 


DO 


45 


247* 


0111 


F7 






7 


0040 


7 


F7 


07 (L) 


D4 


46 


248* 


1000 


F8 




8 




0020 


8 


F8 


08 (L) 


E4 


07 


249* 


1001 


F9 




9 




0010 


9 


F9 


19 (L) 


E0 


08 


250 


1010 


FA 


12 1 


10 9 8 


2 


E830 












251 


1011 


FB 


12 1 


10 9 8 


3 


E430 












252 


1100 


FC 


12 1 


10 9 8 


4 


E230 












253 


1101 


FD 


12 1 


10 9 8 


5 


E130 












254 


1110 


FE 


12 1 


10 9 8 


6 


EOBO 












255 i 


1111 


FF 


12 1 


10 9 8 


7 


E070 
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APPENDIX B. HEXADECIMAL-DECIMAL CONVERSION CHART 






a 



3 ° 

-< .S 

8 a> 

r! x 






•s a 

^ 3 

W o 

rH O 

-3 xi 

s* 

-t-» 

-ti ST 






•"is 
© 3 
« "9 ^ 

gi fl n 

c a s 
5 -) N 
§ 13 "fi 

•3 a o 

o .B x 
o o „, 

a*i 

o -« o 

*» H a 
<u o 

o-S a 

<B +} .2, 
£ So © 
« ^ 5 

'S'S 

I* 

335 



1 



§ 



8 

-H 3 

1 a 

> 3 



ffi 



• i a> 

-9 $ « 

3 ^ » 

<n X fl) 

1 5 5 



OS 



J8 8 

♦* pi 

—- x! 



2 S 3 

,2 5 "53 « x; § 

" I -8 * 
3~ a 

? «T3 

•L 3 <0 

f. XI T3 



«3 
■S xi 

■8-s 

"& ft 
S.8 



3*3 

O 3 



3*3 

h a 



Si 

•iH X 



^ .2 

g 13 

o <B 

o -^ 

° 13 

w « 

s a 

8 1 



Bt 



O g) 
(D X 

•o o 

73 ** 
<D CO 

!§ o 
c -9 

& a 

31 

+* a 

a '3 

X fl> 

H -S 



§ * 8 

XI « C 



8 
a 

2 c 

g| « 
.§ S o. 
o 'a a 

■o 5 g 

O a, » 



g 5 13 

a S I 

S5£ 



u. §§g§ §SSS §g§§ ssig 8s&3 iSSI %%U §§s8 S§?8i ss§i g§5g Hg£° §iSS si 



S|§ g£gg ssss nig gsgg ggg; a§s§ ;gsg gggg 3§|| g 3 sg gsgg S gg 2 ggga 



!i 1=11 ills Iiii ills Iiii s§ii ill! 111! iiil ills! sg§l 
II %V£* 3§?S le'ig Hi?!l gggf %i%% %%*% nil gill Ills ?!?£<? 



3d oo oo 55 oc 55 2S oi o> cb <K is Si c < 



?gSi §=5S §£SS Siss ail!§ ^sSi ?S«S Siss S$Si sill ss^ S^Eg 



iiil ill! iiil iiil ill! iiil iiil iiil llll iiii Iiil !§§! 
iiil 111! Iiil llll fill iiil III! fill iiil iiil Iiil Iiil 
iiii llll llll llll fill llll llll llll llll llll llll llll 
llll §=§§ §£§1 s§8& gggg %m% 53?i §IkS §§ss iiii gigs gggg 



2$S So 
- = E gSJSs 



?: 2 



§^553" S9^ H SS©tr 
oo oo ao oo oo oo o* o> o) ot d> 

aw-^b noiiflH t-cooaift ■r'trc^ 

ISHS aSiS §3£K iH 



fill ill! iiii iiil iiii iiii Iiii Iiii llll iiii Ills llll 
ill! §§§§ §|i| mi mi mi mi mi ggg§ nil fug mi 

iiil iiii llll llll iiii MM Hi! Iiil iiii iiil iiil llll 

§3§& §§§£ SSSi 2g§§ gS^e Ss?^ ?§?§ S?§§ 88S& is§s S8iS ssgg 



S5M3 (pr-Sc S*TlOf sCJ«Mn 

i-ooocoo oBooaocS 0>ot5S1» ftcqo 

^^--H "I^FH^ ^^H^-H -H<NC3C1 

r-aooooo 0000008 SSSbJ ftccp 

jD-^t-n Pjw-*tr HSKJ"* fcQ^SQ 



Iiil Iiii 111% Iiii MM iiii Iiii lipl iiii iiii iiii HE iiil iiii Iiil 

iigg §£3£ sssg gin §gs| ^s^8 Wtt m%$ §m ss§s IsIS §g«E l§gs gg|§ Ss§i 



o ilii§I§ssssis§|g gggg SSSS 53f 5 €3S§ SSSS §SSi iiSS S5SE giilSSlIlisi 



L L 



1 1 1 1 1 1 • 1 1 1111 1111 1111 1111 1111 1111 1111 1111 1111 

3 333 39$!; $$<£ SS!S5 skss sasfe SSSS «ggfe 8SSS S8$£ S8Sg ^Sgfe 



llll llll llll llll 

o -h d eo Ttncoh- 00 o» < ffl UQUb. 
t~r-t^t^ t-r~r-t- i-t-t-r- i-r-t-r- 



£ 



«j«i-i 

iiii 



SSSS 0S0S 

gssg 9SSS 

80SS SSSS 

05OO OOOO 

gggs ssgs 

SSSS SSSS 



So S SSi 



SSSS SSSS 

ISSS S2SS 

8SSS SSSS 

SSSS SSSS 

£§ — § §2§3 
SSSS SSSS 

g|SS SSBS 

SSSS SSSS 

iii= 3SS3 

OOOO OOOO 



iiil 



isis 



!§§S 



33 SSi 



iSSS; SSSS 53SS 

isli isss iigg 



sSteS 2S«£ 
ISSB SESB 



!8 23S8 

Is sssis 



ng>io-^ ^S 01 ^ «^ooi w 5!fe?3 



1 00 3 o <p ci 00 



££SS 



iss; 



fri ^ if? r- 



>m»j Qegoo tcc<m 

?^«3; OhOko Cl^iftf' 

!3SS S3S8 SS^S 



'S t:S§!2 
IB BBBB 



IS 2^53 
IB &BB& 



* t- « 01 u> — r 



J — l> CO C> « ^h 



. . . • « 01 

BBSS SIS? 



ss2g?, 5S}?g isss f-'gss 
bbss ilss Isig si§s 



100 to; 

ills! 



S3 



Cl OC T O <C M 00 



!S3 



ssls 

^09 ci oe T 

338 8§g 

sis Is 

PS3 g? 



g£U> 



lis si 
25 S| 



BBSS 



I fcP S t: ^ S K? ^ 



388 



>3S SSSS 

Jo - c5 9 o fi 

!©S SSSS 
3 SSSS 

OOOOO 



ssls 



88! 
i-«t 
8£2s 

SB rl OC • 

iiii 



Isil 



[828 

less 



BBBB 



2gi!?S 
BBBB 



2§5g 
BBBB 



= &3S 
BBBB 



BBBB 



BBBB 



S5i?S 
BBBB 



;BSS SSSs 



CT © c o 



: Sg« iSti gr.BR Sffiss 
:£ig s^ii ggss slss 

J sg5; §sgi issh ssss 
■ sis issi Issl Ilss 



llll llll Iiii Ills 



;&ls 



gob C ci 
BiS 



!2S£ 
Jggg 



-<t^c33> SQ^tr^ 



iiil 



8 = i 

ssl 



SSSS 



Oil 



liiisii! 



Ill 



iliS §3sE §i^a 

ic.oo 0000 00SS 

So OOOO OOOO 



lis; 



[28 

[33 



[ill 5111 888$' 

s 5111 Slss iiii 



!S BS3SK 
!8 BBBB 



sasa 

BBBB 



85BS 
BBBB 



SSSK 
BBBB 



ills in 

bbss slss lis 
BESS sill lii 






>i§2 



llll 

SSSS 



llll llll 

38SB SSSS 



1111 



1111 1111 1111 1111 1111 

222t 2232 y9sis s^aa saa& 



OOO -* — « " " ~ " " " " ~« ?-" " " M »H 



llll llll 



1111 1111 1111 1111 

8-gg aiast SSSJSB ySSfe 
Ortrs rtrtrtco rtcortrt nrtoo 



38 



L L 



c?s^ 12 2222 ?j — ■ co *? S »- o? ^ & 

Scoeoco ooon cocoeoco ??«??« 

SS2S SSSSS 2||8 S52S 

nnon eo co to eo noon co co co co 

§§=§ ?s»s sggg sg§a 

PS CO CO CO CO CO CO CO CO CO CO CO CO CO CO CO 

SO CO Cl 0OTQ$P.dOOT© CO Cl CO T 
C'-HCO T CD 00 0> —< d T CD t^O)Q(N 

c5 eo co co coeococo concoco co co r5 co 
co co eo co coeococo coeococo coeococo 

So 3> 2 8 *° Jo °° 3! £ * M 2R tc*« 



co o> tn — • t <"! o^ »o *-• t- qo) in —< t- < 

3 in t- o> © ci ft in r-ooon co in <p c 

d co t o <o ci oot © ep d co 3 © cp « 

Srtco Q d eo W t-060-H nRSc 

«-« 1- co o> U0 — * t» CO O) wj -• r- CO Oi UJ — • 

coMcoco coeococo cococOc-5 co co co eO 

© (pd ao 2 °. J6 M $ ^ £ ^ ^ °° 2, 2 

rtonrt t t *r *r "f *>■?") SioSS 

cotOrtrt COCOCOCO CO cO e-5 co coeococo 



Hhno! 10 — r- eo 



g> m -< r- co < 



> ci ao f Ctoei «-rCffi cioctTO 
5 — ci t cor- o> CCIflP 1- ao © ci 



01 in ~h £- c0O>iQi-h r-cogJW -t-OO) 

2 "5 £; S8 5. ^ £2 ^2 SB. °o 5 s — ' eo t co r- 

3333 SS33 3333 3338 

33S3 §238 SSS2 33S£ 

3333 3333 3333 3333 

SSS3 SE3? SSS2 £!?££ 

3333 3333 3333 3333 



SB cl 2£ 2 CCDCI00 T Q COd OCVQCD d QOT © CO d 00 T 

S2 £ Sfi 9°. o — < co t co cc d> -* d t 2 t- 0)S<M t in t- 55 © 

3333 3333 3333 3333 3333 333S 



S w r2*~ rtC7>iO^ t-offlw Tr'tr^S 

533 $ to § ^ N^ioF- OJ Q d e 

op^Q« d oo a* O cod oo t © QD d 

Ss*5t <© ?r y* ~ H d t in t- o> © ci c 

SB SB SB SB SB SB *- t- t- t- t- r- Q0 ao o 
COCOCOcO coeococo coeococo cOcortc 
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